Mysql自定义排序,order by问题

自定义

常用的order by已经可以解决大部分问题,但如下问题却不好解决:
状态status,0:申请,1:通过,-1拒绝
此时新申请的在前,通过在后,拒绝的最后

SELECT * FROM `MyTable` 
ORDER BY FIELD(`status`, 0, 1, -1)

同时,此处的FIELD内部,可以是字符串,如下;

SELECT * FROM `MyTable` 
WHERE `name` IN ('张三', '李四', '王五', '孙六') 
ORDER BY FIELD(`name`, '李四', '孙六', '张三', '王五')

猜你喜欢

转载自blog.csdn.net/kk1946n/article/details/77568600