Oracle 排序中NULL值的处理方法
[url]http://space.itpub.net/15203236/viewspace-588848[/url]
1、缺省处理
Oracle在Order by时缺省认为null是最大值,所以如果是ASC升序则排在最后,DESC降序则排在最前面。
2、使用nvl函数
nvl函数可以将输入参数为空时转换为一特定值,如nvl(employee_name,’张三’)表示当employee_name为空时则返回’张三’,如果不为空则返回employee_name。通过这个函数可以定制null的排序位置。
3、使用decode函数
decode函数比nvl函数更强大,同样它也可以将输入参数为空时转换为一特定值,如decode(employee_name,null,’张三’, employee_name)表示当employee_name为空时则返回’张三’,如果不为空则返回employee_name
通过这个函数可以定制null的排序位置。
4、使用case语法
Case语法是Oracle 9i后开始支持的,是一个比较灵活的语法,同样在排序中也可以应用。如:
select * from employee
[b]order by case when employee_name is null then 0 else 1 end,employee_name
(按employee_name升序排列,并将employee_name为null的排在最前面)[/b]
5、使用nulls first或者nulls last语法
Nulls first和nulls last是Oracle Order by支持的语法:
如果Order by中指定了表达式Nulls first则表示null值的记录将排在最前(不管是asc还是desc)
如果Order by中指定了表达式Nulls last则表示null值的记录将排在最后(不管是asc还是desc)
使用语法如下:
--将nulls始终放在最前面
select * from emp order by comm nulls first
--将nulls始终放在最后面
select * from emp order by comm nulls last
[url]http://space.itpub.net/15203236/viewspace-588848[/url]
1、缺省处理
Oracle在Order by时缺省认为null是最大值,所以如果是ASC升序则排在最后,DESC降序则排在最前面。
2、使用nvl函数
nvl函数可以将输入参数为空时转换为一特定值,如nvl(employee_name,’张三’)表示当employee_name为空时则返回’张三’,如果不为空则返回employee_name。通过这个函数可以定制null的排序位置。
3、使用decode函数
decode函数比nvl函数更强大,同样它也可以将输入参数为空时转换为一特定值,如decode(employee_name,null,’张三’, employee_name)表示当employee_name为空时则返回’张三’,如果不为空则返回employee_name
通过这个函数可以定制null的排序位置。
4、使用case语法
Case语法是Oracle 9i后开始支持的,是一个比较灵活的语法,同样在排序中也可以应用。如:
select * from employee
[b]order by case when employee_name is null then 0 else 1 end,employee_name
(按employee_name升序排列,并将employee_name为null的排在最前面)[/b]
5、使用nulls first或者nulls last语法
Nulls first和nulls last是Oracle Order by支持的语法:
如果Order by中指定了表达式Nulls first则表示null值的记录将排在最前(不管是asc还是desc)
如果Order by中指定了表达式Nulls last则表示null值的记录将排在最后(不管是asc还是desc)
使用语法如下:
--将nulls始终放在最前面
select * from emp order by comm nulls first
--将nulls始终放在最后面
select * from emp order by comm nulls last