欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2022-05-01 16:22:19
...
数据库有列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

相关标签: php mysql sql