mysql 一个字段多种状态自由排序

order 表中有一个 status 字段,该字段有 1,2,3,4,5 五种状态,现在需要根据 status 字段排序,排序规则是 1,2为一种状态a,3,4为一种状态b,5为一种状态c,然后根据a,b,c排序

希望能得到帮助!!感谢!

阅读 2.8k
2 个回答

select * from table order by (status=1 or status=2) DESC,(status=1 or status=2) DESC,(status=5) DESC;

你可以再加个状态组字段status_group,然后使用这个字段排序,可以直接用sql实现,不用实际创建这个字段,但是影响查询效率不推荐使用,你可以更新状态时,顺便更新这个组状态

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题