Rumah  >  Artikel  >  pembangunan bahagian belakang  >  关于数据库指定规则排序的问题

关于数据库指定规则排序的问题

WBOY
WBOYasal
2016-08-04 09:21:43907semak imbas

数据库有列store储存着商城名字,现在想让商城为淘宝,亚马逊排在前面,其余商城按数据创建时间排序,而且需要分页。
有想方案
一 mysql有提供按field排序的方法,但是filed必须包含数据库已存在的所有商城类型,不然没包括的会打乱排序,但是store下的商城(比如日亚等等)会陆续增加,所以这条sql语句就要持续更改了。于是想请教有没有什么很好的方案。
二 增加一个字段对应store的数字id,按数字id排序,但是产品现在是想让 淘宝,亚马逊排在前面,但是朝令夕改想让日亚排在前面,那这套逻辑岂不是打乱了。
请教各位有什么好的方案。

回复内容:

数据库有列store储存着商城名字,现在想让商城为淘宝,亚马逊排在前面,其余商城按数据创建时间排序,而且需要分页。
有想方案
一 mysql有提供按field排序的方法,但是filed必须包含数据库已存在的所有商城类型,不然没包括的会打乱排序,但是store下的商城(比如日亚等等)会陆续增加,所以这条sql语句就要持续更改了。于是想请教有没有什么很好的方案。
二 增加一个字段对应store的数字id,按数字id排序,但是产品现在是想让 淘宝,亚马逊排在前面,但是朝令夕改想让日亚排在前面,那这套逻辑岂不是打乱了。
请教各位有什么好的方案。

这个问题得两个字段:一个是weight(权重),一个是 sort(排序字段),
你这样子

  1. 淘宝: weight: 100 sort: 1,

  2. 亚马逊:weith: 100 sort: 2,

  3. 日亚: weight: 100 sort: 3

  4. 其他: weight: 1 sort: 1

  5. ...

你的 sql 这么写:select * from table order by weight * sort,这样就解决了。如果要改权限的话,可以调整 weight,也可以改 sort

复杂逻辑排序,不要在数据库层,应该放到代码层,比如放到一个可排序的数组或者map里,自己定义排序规则即可,jdk很多排序的数组和map

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn