《SQL CookBook 》笔记-第二章-查询结果排序
2.1 以指定顺序返回查询结果
问题:
你想显示部门编号为 10 的员工的名字、职位和工资,并根据工资从低到高排序。
解决方案:
使用order by column_Name
代码如下:
select ename,job,sal,hiredate
from emp
where deptno = 10
order by sal asc
当然你可以使用多字段排序
比如先按照sal升序排序,然自后按照入职日期降序排列
select ename,job,sal,hiredate
from EMP
where deptno = 10
order by sal asc,hiredate desc
【注意】
order by默认是升序,即ASC- 降序则使用
DESC - 在同时使用 ORDER BY 和 WHERE 子句时,应该让 ORDER BY 位于
WHERE 之后,否则将会产生错误
2.2 依据子串排序
问题:
按照一个字符串的特定部分排列查询结果。
例如:
希望从 EMP 表检索10号部门的员工的名字和职位,并且按照职位字段的最后两个字符对检索结果进行排序。
解决方案:
在 order by 子句里使用 substring() 函数。
代码如下:
select ename,job
from EMP
where deptno=10
order by substring(job,len(job)-2,2)
结果:
| ename | job |
|---|---|
| KING | PRESIDENT |
| MILLER | CLERK |
| CLARK | MANAGER |
【分析】
substring() 函数
第一个参数:字符串所在列的列名
第二个参数:取子串的开始位置
第三个参数:所取的子串的长度
2.3 排序时对 Null 值的处理
问题:
排序依据的列中有null,把该列的值为null的行放在最后
例如:你想按照 EMP 表的 COMM 列对查询结果进行排序,但该字段可能为 Null 。非 Null 值以升序排列或降序排列,把全部 Null 值都放到最后面
解决方案:
使用 CASE 表达式来动态调整排序项。
代码下:
select ename,sal,comm
from
(
select ename,sal,comm,
case when comm is null then 0
else 1
end as is_null
from emp
)X
order by is_null desc,comm
结果如下:
| ename | sal | comm |
|---|---|---|
| TURNER | 1500 | 0 |
| ALLEN | 1600 | 300 |
| WARD | 1250 | 500 |
| MARTIN | 1250 | 1400 |
| BLAKE | 2850 | NULL |
| CLARK | 2450 | NULL |
| SCOTT | 3000 | NULL |
| KING | 5000 | NULL |
| ADAMS | 1100 | NULL |
| JAMES | 950 | NULL |
| FORD | 3000 | NULL |
| MILLER | 1300 | NULL |
| JONES | 2975 | NULL |
| SMITH | 800 | NULL |
此处你得想明白,这里面的子查询表X,都是临时的,其中is_null就是一个辅助列,我们按照这个列来排序。
其中子查询:
select ename,sal,comm,
case when comm is null then 0
else 1
end as is_null
from emp
结果如下:
| ename | sal | comm | is_null |
|---|---|---|---|
| SMITH | 800 | NULL | 0 |
| ALLEN | 1600 | 300 | 1 |
| WARD | 1250 | 500 | 1 |
| JONES | 2975 | NULL | 0 |
| MARTIN | 1250 | 1400 | 1 |
| BLAKE | 2850 | NULL | 0 |
| CLARK | 2450 | NULL | 0 |
| SCOTT | 3000 | NULL | 0 |
| KING | 5000 | NULL | 0 |
| TURNER | 1500 | 0 | 1 |
| ADAMS | 1100 | NULL | 0 |
| JAMES | 950 | NULL | 0 |
| FORD | 3000 | NULL | 0 |
| MILLER | 1300 | NULL | 0 |
【注意】
此例在 FROM 子句里用到了内嵌视图(即子查询)。
ANSI SQL 标准规定要给它们取别名。
(只有 Oracle 不要求指定这一类别名。)因此,我在解决方案里经常用类似 X 和 Y 这样的别
名来标识内嵌视图。
注意最后紧挨着圆括号的字母 X 。
在这里,字母 X 变成了 FROM 子句里那个子查询返回的表的名字。
列别名是一个有用的工具,能帮我们写出自注释的代码;
相对而言,(本书中出现过的多数)内嵌视图的别名只是一种形式化的东西。
通常我会为它们取一个简单的名字,诸如 X 、 Y 、 Z 、 TMP1 和 TMP2 。
2.4 依据条件逻辑动态调整排序项
问题:
你希望按照某个条件逻辑来排序。
例如:
如果 job 等于 salesman ,就要按照 comm 来排序;否则,按照 SAL 排序
解决方案1:
在 order by 子句里使用 case 表达式。
代码下:
select ename,sal,job,comm
from emp
order by
case when job = 'SALESMAN' then comm
else sal
end
【注意】case子句还可以在select句中使用。
你可记否?在select子句中时,case子句的end子句的最后要使用as定义一个列名
记住了,不论在哪,case子句的基础格式都是:
case when condition1 then return_value1
case when condition2 then return_value2
else return_default_value
end
解决方案2:构造辅助列
注意case语句的返回值。
select ename,sal,job,comm,
case when job = 'SALESMAN' then comm
else sal
end as ordered
from emp
order by ordered
《SQL CookBook 》笔记-第二章-查询结果排序的更多相关文章
- 第二章 约束和排序数据(SQL基础)
第二章 约束和排序数据 1. 在 emp 表中选择工资介于 1500 到 2500 的员工的信息: 注意:使用 between 下边界 and 上边界时,条件包括边界值: ...
- sql系列(基础)-第二章 限制和排序数据
更好的看↑代码点击VIEW PLAN 第二章 约束和排序数据 1. 在 emp 表中选择工资介于 1500 到 2500 的员工的信息: 注意:使用 between 下边界 and 上边界时.条件包括 ...
- Android群英传笔记——第二章:Android开发工具新接触
Android群英传笔记--第二章:Android开发工具新接触 其实这一章并没什么可讲的,前面的安装Android studio的我们可以直接跳过,如果有兴趣的,可以去看看Google主推-Andr ...
- 《DOM Scripting》学习笔记-——第二章 js语法
<Dom Scripting>学习笔记 第二章 Javascript语法 本章内容: 1.语句. 2.变量和数组. 3.运算符. 4.条件语句和循环语句. 5.函数和对象. 语句(stat ...
- The Road to learn React书籍学习笔记(第二章)
The Road to learn React书籍学习笔记(第二章) 组件的内部状态 组件的内部状态也称为局部状态,允许保存.修改和删除在组件内部的属性,使用ES6类组件可以在构造函数中初始化组件的状 ...
- 深入理解 C 指针阅读笔记 -- 第二章
Chapter2.h #ifndef __CHAPTER_2_ #define __CHAPTER_2_ /*<深入理解C指针>学习笔记 -- 第二章*/ /* 内存泄露的两种形式 1.忘 ...
- [HeadFrist-HTMLCSS学习笔记]第二章深入了解超文本:认识HTML中的“HT”
[HeadFrist-HTMLCSS学习笔记]第二章深入了解超文本:认识HTML中的"HT" 敲黑板!!! 创建HTML超链接 <a>链接文本(此处会有下划线,可以单击 ...
- Getting Started With Hazelcast 读书笔记(第二章、第三章)
第二章 起步 本章就相当简单粗暴了,用一个个例子说明hazelcast怎么用. 1.map,set,list这些集合类都是开箱即用的,只要从Hazelcast的实例中获取一份就行. 2.增加了Mult ...
- STL源码分析读书笔记--第二章--空间配置器(allocator)
声明:侯捷先生的STL源码剖析第二章个人感觉讲得蛮乱的,而且跟第三章有关,建议看完第三章再看第二章,网上有人上传了一篇读书笔记,觉得这个读书笔记的内容和编排还不错,我的这篇总结基本就延续了该读书笔记的 ...
随机推荐
- Netty_TCP拆包粘包解决方案
一.问题 熟悉tcp编程的可能都知道,无论是服务器端还是客户端,当我们读取或者发送数据的时候,都需要考虑TCP底层的粘包/拆包机制. TCP是一个“流”协议,所谓流就是没有界限的遗传数据,大家可以想象 ...
- springboot项目利用devtools实现热部署,改动代码自动生效
一.前言 spring-boot-devtools是一个为开发者服务的一个模块,其中最重要的功能就是自动应用代码更改到最新的App上面去.原理是在发现代码有更改之后,重新启动应用,但是速度比手动停止后 ...
- vue入坑教程(一)
1.脚手架搭配webpack的安装 (1)需要检查自己的电脑有没有安装node和npm 如果没有安装可以参考官网,以及安装的步骤 官方中文网地址:http://nodejs.cn/ (2)下载webp ...
- SSM-SpringMVC-03:SpringMVC执行流程一张有意思的图
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 上次的图也不全,这次的图也不是完整版,但是多了一个拦截器,我觉得挺有意思的,我就放上来了 他Handler ...
- ansj构造最短路径
一.前言 上节介绍了ansj的原子切分和全切分.切分完成之后,就要构建最短路径,得到分词结果. 以"商品和服务"为例,调用ansj的标准分词: String str = " ...
- Springboot2.0(Spring5.0)中个性化配置项目上的细节差异
在一般的项目中,如果Spring Boot提供的Sping MVC不符合要求,则可以通过一个配置类(@Configuration)加上@EnableWebMvc注解来实现完全自己控制的MVC配置.但此 ...
- Oracle .NET Core Beta驱动已出,自己动手写EF Core Oracle
使用.net core也有一段时间了,一直都没有Oracle官方的正式版驱动程序,更别说EF版本了.之前基于Oracle官方的.net core预览版本写了个Dapper的数据库操作实现,但是总感觉不 ...
- 爬虫之scrapy-splash
什么是splash Splash是一个Javascript渲染服务.它是一个实现了HTTP API的轻量级浏览器,Splash是用Python实现的,同时使用Twisted和QT.Twisted(QT ...
- Ubuntu基础教程——安装谷歌Chrome浏览器
对于刚刚开始使用Ubuntu并想安装谷歌Chrome浏览器的新用户来说,本文所介绍的方法是最快捷的.在Ubuntu上安装谷歌Chrome的方法有很多.一些用户喜欢直接在 谷歌Chrome下载页面 获得 ...
- Go语言Context(设计及分析)
context简单概述: Go服务器的每个请求都有自己的goroutine,而有的请求为了提高性能,会经常启动额外的goroutine处理请求,当该请求被取消或超时,该请求上的所有goroutines ...