欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

oracle 排序空值处置

更新时间: 2014-01-05 02:06:01 责任编辑: Author_N1

 

oracle 排序空值处理
oracle认为 null 最大。
    升序排列,默认情况下,null值排后面。

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

    改动空值办法:

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

    替换null: nvl(arg,value)

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

    order by (case mycol when null then‘北京’else mycol end)

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

    null值排序的语法

    nulls first :将null排在最前面。如:

    select *

    from mytb

    order by mycol nulls first

    null last :将null排在最后面。如:

    select *

    from mytb

    order by mycol nulls last

    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

    替换null:isnull(arg,value)
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:06:01
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/5619/
本文WWW.DOC100.NET DOC100.NET版权所有。