sql排序,null排在最前/最后----mysql排序之if(isnull(字段名),0,1),fild 或者 if(isnull(字段名),1,0),fild
2021/5/21 19:29:50
本文主要是介绍sql排序,null排在最前/最后----mysql排序之if(isnull(字段名),0,1),fild 或者 if(isnull(字段名),1,0),fild,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
最近在使用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
这篇关于sql排序,null排在最前/最后----mysql排序之if(isnull(字段名),0,1),fild 或者 if(isnull(字段名),1,0),fild的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-09-21MySQL集群部署资料:新手入门教程
- 2024-09-21MySQL集群资料:初学者入门指南
- 2024-09-21部署MySQL集群资料:新手入门教程
- 2024-09-20MySQL集群部署教程:新手入门指南
- 2024-09-20MySQL集群教程:初学者必备指南
- 2024-09-20部署MySQL集群项目实战:新手入门教程
- 2024-09-20如何部署MySQL集群:简单教程
- 2024-09-20MySQL集群部署:新手入门指南
- 2024-09-20部署MySQL集群学习:入门指南
- 2024-09-20部署MySQL集群入门教程