最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle对SQL排序后NULL值位置的“特殊关照”

来源:懂视网 责编:小采 时间:2020-11-09 11:55:54
文档

Oracle对SQL排序后NULL值位置的“特殊关照”

Oracle对SQL排序后NULL值位置的特殊关照:Oralce对NULL值的排序后的位置有一个特殊的ldquo;关照rdquo;,这就是ldquo;NULLS FIRSTrdquo;和ldquo;NULLS LASTrdquo;选项 Oralce对NULL值的排序后的位置有一个特殊的关照,这就是NULLS FIRST和NULLS LAST选项,使用这个
推荐度:
导读Oracle对SQL排序后NULL值位置的特殊关照:Oralce对NULL值的排序后的位置有一个特殊的ldquo;关照rdquo;,这就是ldquo;NULLS FIRSTrdquo;和ldquo;NULLS LASTrdquo;选项 Oralce对NULL值的排序后的位置有一个特殊的关照,这就是NULLS FIRST和NULLS LAST选项,使用这个

Oralce对NULL值的排序后的位置有一个特殊的ldquo;关照rdquo;,这就是ldquo;NULLS FIRSTrdquo;和ldquo;NULLS LASTrdquo;选项

Oralce对NULL值的排序后的位置有一个特殊的“关照”,这就是“NULLS FIRST”和“NULLS LAST”选项,使用这个选项便可以在SQL排序中强制指定NULL值出现的位置(是显示在最前,还是显示在最后)。演示并总结在此,供参考。

1.创建演示表T并初始化7条数据
sec@ora10g> create table t (x int);
sec@ora10g> insert into t values (1);
sec@ora10g> insert into t values (2);
sec@ora10g> insert into t values (3);
sec@ora10g> insert into t values (4);
sec@ora10g> insert into t values (null);
sec@ora10g> insert into t values (null);
sec@ora10g> insert into t values (null);
sec@ora10g> commit;

2.不加“关照”的order by升序排序效果--NULL值在后。
sec@ora10g> select * from t order by x;

X
----------
1
2
3
4


7 rows selected.

3.不加“关照”的order by降序排序效果--NULL值在前。
sec@ora10g> select * from t order by x desc;

X
----------

4
3
2
1

7 rows selected.

4.特殊“关照”的order by升序排序效果--NULL值在前。
sec@ora10g> select * from t order by x nulls first;

X
----------

1
2
3
4

7 rows selected.

5.特殊“关照”的order by降序排序效果--NULL值在后。
sec@ora10g> select * from t order by x desc nulls last;

X
----------
4
3
2
1


7 rows selected.

6.规律总结
1)不加“关照”的情况下,我们可以把那些NULL值假想为所有内容中值是最大的,,因此,升序排序后NULL值在最后,倒序排序后NULL值在最前!
2)特殊“关照”的情况下,当指定“NULLS FIRST”时,无论是升序排序还是倒序排序,NULL值都会排列在最前面;当指定“NULLS LAST”时,无论是升序排序还是倒序排序,NULL值都会排列在最后面。

7.Oracle官方文档中有关“NULLS FIRST | NULLS LAST”的参考内容
#i2171079
摘录在此:
NULLS FIRST | NULLS LAST
Specify whether returned rows containing null values should appear first or last in the ordering sequence.
NULLS LAST is the default for ascending order, and NULLS FIRST is the default for descending order.

8.小结
通过这篇内容的介绍,我们可以看到Oracle的确是无微不至。有了这个NULL值位置的强制方法,我们在书写SQL时的灵活性和可控性便可进一步得到加强。

linux

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

Oracle对SQL排序后NULL值位置的“特殊关照”

Oracle对SQL排序后NULL值位置的特殊关照:Oralce对NULL值的排序后的位置有一个特殊的ldquo;关照rdquo;,这就是ldquo;NULLS FIRSTrdquo;和ldquo;NULLS LASTrdquo;选项 Oralce对NULL值的排序后的位置有一个特殊的关照,这就是NULLS FIRST和NULLS LAST选项,使用这个
推荐度:
标签: sql 排序 特殊
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top