博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
阅读量:6700 次
发布时间:2019-06-25

本文共 1607 字,大约阅读时间需要 5 分钟。

hot3.png

【sqlserver】:

sqlserver 认为 null 最小。

升序排列:null 值默认排在最前。

要想排后面,则:order by case when col is null then 1 else 0 end ,col

降序排列:null 值默认排在最后。

要想排在前面,则:order   by case when col is null then 0 else 1 end , col desc

【oracle】:

oracle认为 null 最大。

升序排列,默认情况下,null值排后面。

降序排序,默认情况下,null值排前面。

有几种办法改变这种情况:

(1)用 nvl 函数或decode 函数 将null转换为一特定值

(2)用case语法将null转换为一特定值(oracle9i以后版本支持。和sqlserver类似):

order by (case mycol when null then '北京漂客'     else   mycol   end)

(3)使用nulls first 或者nulls last 语法。

这是oracle专门用来null值排序的语法。

nulls first :将null排在最前面。如:select * from mytb order by mycol nulls first

null last :将null排在最后面。如:select * from mytb order by mycol nulls last

如果要想让含有null的列按照自己的意愿进行排序,可做如上处理。

【mysql】:

MySQL同sqlserver,null默认最小,解决办法同sqlserver

注意:
1、null的列作为查询条件时,无论使用>/</>=/<=都是不符合条件的,只能使用isNull来判断。如下:

id为4的age字段为空,

执行SQL:select * from student where age >= 30; 结果如下:

执行SQL:select * from student where age < 30; 结果如下:

只有执行SQL:select * from student where age is null; 才能查询出age为null的数据。

2、对null做加、减、乘、除等运算操作,结果仍为空

刚开始student表数据如下:

执行SQL:update student set age = age + 20;

执行SQL:select * from student; 结果如下:

非null的age字段都更新为+20,而null字段依然为空。

上面的测试数据库为MySQL,Oracle也一样。SQL Server没测试过,应该也是一样的。

空值

列可以接受或拒绝空值。在数据库内 NULL 是特殊值,代表未知值的概念。NULL 不同于空字符或 0。空字符实际上是有效字符,0 是有效数字。而 NULL 只是表示该值未知这一概念。NULL 也不同于零长度字符串。如果列定义中包含 NOT NULL 子句,则不能为该行插入含有 NULL 值的行。如果列定义中仅包含 NULL 关键字,则接受 NULL 值。
在列内允许 NULL 值会增加使用该列的逻辑比较的复杂性。SQL-92 标准规定:对 NULL 值的任何比较都不取值为 TRUE 或 FALSE,而是取值为 UNKNOWN。此规定在比较运算符中引入了三值逻辑,而要正确运用该逻辑很困难。[摘自Microsoft SQLServer联机丛书]

SQL中null值索引优化的文章:

转自:http://blog.csdn.net/smcwwh/article/details/6927613

转载于:https://my.oschina.net/u/2353726/blog/506884

你可能感兴趣的文章
37signals为何砍掉中层?个人点评,高素质人才队伍工作,靠的是全体发挥综合能力,而不是靠......
查看>>
从表到里学习JVM实现
查看>>
关于数据库查询优化的思考
查看>>
如何在android studio中设置sdk path?
查看>>
iptables的SNAT和DNAT应用
查看>>
搭建LNMP遇到的问题
查看>>
java String类 常用函数
查看>>
Windows下C语言连接Oracle数据库
查看>>
Cacti 使用安装详解-企业级实例
查看>>
ASP.NET后台调用前台JS函数的三种常见方法
查看>>
MeasureSpec学习 - 转
查看>>
nodejs express
查看>>
系统设计学习
查看>>
iOS游戏开发 几个有利工具
查看>>
HashMap vs ConcurrentHashMap — 示例及Iterator探秘
查看>>
程序图片运行效果存在偏差问题
查看>>
基于环信sdk的陌生人交友php服务器代码开源
查看>>
STL 容器和迭代器连载6_顺序容器的操作3
查看>>
JDBC学习笔记——事务、存储过程以及批量处理
查看>>
Spring JDBC最佳实践(2)
查看>>