最近在使用mysql排序的时候,比如按照sort排序,于是 : select filds from table order by sort asc
但null排在前面。
看到同事是这样处理的:IF(ISNULL(sort1),1,0), sort1。
默认情况下,mysql将null算作最小值。如果想要手动指定null的顺序,可以这样处理:
1. 将null强制放在最前(默认就是这样)
SELECT * FROM BGM_LIST ORDER BY if(isnull(SORT),0,1),SORT ASC //null, null, 1,2,3,4
2. 将null强制放在最后
SELECT * FROM BGM_LIST ORDER BY if(isnull(SORT),1,0),SORT ASC //1,2,3,4,null,null
SELECT * FROM BGM_LIST ORDER BY if(isnull(SORT),1,0),SORT DESC // 4,3,2,1,null,null
3. 解释
以if(isnull(字段名),0,1),fild为例,它的意思是将该字段根据是否为null值分成两部分,值为null行相当于得到了一个隐含的排序属性0,值为非null的行相当于得到了一个隐含的排序属性1,在排序的时候,先根据这一隐含属性进行升序排列,因为if(isnull(字段名),0,1),fild相当于if(isnull(字段名),0,1),fild asc省略了asc而已,所以自然地,排序字段为null的那些行(隐含排序属性)会在最前。if(isnull(字段名),1,0)反之。
————————————————
版权声明:本文为CSDN博主「cyj7696」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/cyj7696/article/details/106927485