背景
最近在使用mysql排序的时候,比如按照sort排序,于是 : select filds from table order by sort asc
后来发现null的排在前面了。不是我们想要的。找了点资料看了下,记录下来。
默认情况下,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)
反之。
全文完。。。
网友评论