Maison > développement back-end > tutoriel php > 关于数据库指定规则排序的问题

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

WBOY
Libérer: 2016-08-04 09:21:43
original
920 Les gens l'ont consulté

数据库有列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

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal