一起聊聊ORACLE中ORDER BY的多种排序

本篇文章给大家带来了关于Oracle的相关知识,其中主要介绍了关于ORDER BY多种排序的相关问题,包括了按单个字段排序、按多个字段排序、按子串排序等等,希望对大家有帮助。 推荐教

    本篇文章给大家带来了关于Oracle的相关知识,其中主要介绍了关于ORDER BY多种排序的相关问题,包括了按单个字段排序、按多个字段排序、按子串排序等等,希望对大家有帮助。

推荐教程:《Oracle学习教程》

1. 按单个字段排序

升序:ORDER BY ASC(默认)

降序:ORDER BY DESC

以指定的次序返回查询结果实际提取数据或生成报表时,一般都要根据一定的顺序查看,比如,想查看单位所雇员工的信息。

给查询结果排序这种语句很多人都会写,但除了“ORDER BY hiredate ASC”这种写法外,还可以写成“ ORDER BY 3 ASC”,意思是按第三列排序。

用数据来代替列位置只能用于 order by子句中,其他地方都不能用

2. 按多个字段排序

如果按多列排序且有升有降怎么办?如:按部门编号升序,并按工资降序排列排序时有两个关键字:ASC表示升序、DESC表示降序所以我们在 order by后加两列,并分别标明ASC、DESC。

下面用图的形式进行介绍,如下图所示,多列排序时,若前面的列有重复值(如deptno = 10有3行数据),后面的排序才有用。相当于是通过前面的列把数据分成了几组,然后每组的数据再按后面的列进行排序。

3. 按子串排序

按子串排序有一种速査法就是按顾客电话号码尾号的顺序记录,这样在查找的时候就可以快速缩小査询范围,增强顾客的认可度。如果要按这种方法排序,应该怎么做呢?通过函数取出后面几位所需的信息即可。