SQL Server、Oracle数据库排序空值null问题解决办法
2010-06-21 13:28
471 查看
【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的列按照自己的意愿进行排序,可做如上处理。
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、SQL Server、Oracle数据库排序空值null问题及其解决办法
- MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
- MySQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
- MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
- MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
- SQL Server、Oracle数据库排序空值null问题解决办法(转)
- MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
- sqlserver、oracle数据库排序空值null问题解决办法
- oracle、sqlserver数据库排序空值null问题解决办法
- oracle、sqlserver数据库排序空值null问题解决办法
- oracle、sqlserver数据库排序空值null问题解决办法
- oracle、sqlserver数据库排序空值null问题解决办法
- Oracle数据库order by排序查询分页比不分页还慢问题解决办法
- Oracle数据库order by排序查询分页比不分页还慢问题解决办法
- SQL Server、Oracle数据库排序空值null
- 常见问题及解决办法 整理之10(SQL SERVER 2005 同步复制技术)
- SQL Server 系统日志已满问题(解决办法)
- SQL Server安装问题程序被挂起的错误----解决办法
- 访问jsp报错org.apache.jasper.JasperException: java.lang.NullPointerException的解决办法 问题描述:
- SQL Server中TOP子句可能导致的问题以及解决办法