php - 关于数据库指定规则排序的问题
PHP中文网
PHP中文网 2017-04-11 09:09:06
0
2
319

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

PHP中文网
PHP中文网

认证高级PHP讲师

全部回覆 (2)
左手右手慢动作

这个问题得两个字段:一个是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

      最新下載
      更多>
      網站特效
      網站源碼
      網站素材
      前端模板
      關於我們 免責聲明 Sitemap
      PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!