mysql排序之if(isnull(字段名),0,1),fild 或者 if(isnull(字段名),1,0),fild

背景

最近在使用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)反之。

全文完。。。

你可能感兴趣的:(mysql排序之if(isnull(字段名),0,1),fild 或者 if(isnull(字段名),1,0),fild)