Oracle系列三 过滤和排序
WHERE子句
- 使用WHERE 子句,将不满足条件的行过滤掉。
示例:
SELECT
employee_id,
last_name,
job_id,
department_id
FROM
employees
WHERE
department_id = 90 ;

字符和日期
- 字符和日期要包含在单引号中。
- 字符大小写敏感,日期格式敏感。
示例:
SELECT
last_name,
job_id,
department_id
FROM
employees
WHERE
last_name = 'Whalen';

比较运算
| 操作符 | 含义 |
| = | 等于 |
| > | 大于 |
| >= | 大于等于 |
| < | 小于 |
| <= | 小于等于 |
| <> | 不等于(也可以是!=) |
赋值使用 := 符号
比较运算示例:
SELECT
last_name,
salary
FROM
employees
WHERE
salary <= 3000;

其它比较运算
| 操作符 | 含义 |
| BETWEEN...AND... | 在两个值之间 (包含边界) |
| IN(set) | 等于值列表中的一个 |
| LIKE | 模糊查询 |
| IS NULL | 空值 |
使用 BETWEEN 运算来显示在一个区间内的值
示例一:
SELECT
last_name,
salary
FROM
employees
WHERE
salary BETWEEN 2500 AND 3500;

使用 IN运算显示列表中的值
SELECT
employee_id,
last_name,
salary,
manager_id
FROM
employees
WHERE
manager_id IN (
100,
101,
201
);

LIKE
- 使用 LIKE 运算选择类似的值
- 选择条件可以包含字符或数字:
- % 代表零个或多个字符(任意个字符)。
- _ 代表一个字符。
示例:
SELECT
first_name
FROM
employees
WHERE
first_name LIKE 'S%';

‘%’和‘-’同时使用
示例:
SELECT
last_name
FROM
employees
WHERE
last_name LIKE '_o%';

ESCAPE
- 可以使用 ESCAPE 标识符 选择‘%’和 ‘_’ 符号。
- 回避特殊符号的:使用转义符。例如:将[%]转为[\%]、[_]转为[\_],然后再加上[ESCAPE ‘\’] 即可。
示例:
SELECT
job_id
FROM
jobs
WHERE
job_id LIKE 'IT\_%' ESCAPE '\';

NULL
- 使用 IS (NOT) NULL 判断空值。
SELECT
last_name,
manager_id
FROM
employees
WHERE
manager_id IS NULL;

逻辑运算
| 操作符 | 含义 |
| AND | 逻辑并 |
| OR | 逻辑或 |
| NOT | 逻辑否 |
AND
- AND 要求并的关系为真。
示例:
SELECT
employee_id,
last_name,
job_id,
salary
FROM
employees
WHERE
salary >= 10000
AND job_id LIKE '%MAN%';

OR
- OR 要求或关系为真。
SELECT
employee_id,
last_name,
job_id,
salary
FROM
employees
WHERE
salary >= 10000
OR job_id LIKE '%MAN%';

NOT
- NOT 不在这之内
SELECT
last_name,
job_id
FROM
employees
WHERE
job_id NOT IN (
'IT_PROG',
'ST_CLERK',
'SA_REP'
);
优先级
| 优先级 | 名称 |
| 1 | 算术运算符 |
| 2 | 连接符 |
| 3 | 比较符 |
| 4 | IS [NOT] NULL, LIKE, [NOT] IN |
| 5 | [NOT] BETWEEN |
| 6 | NOT |
| 7 | AND |
| 8 | OR |
- 可以使用括号改变优先级顺序
ORDER BY子句
- 使用 ORDER BY 子句排序
- ASC(ascend): 升序
- DESC(descend): 降序
- ORDER BY 子句在SELECT语句的结尾。
示例:
SELECT
last_name,
job_id,
department_id,
hire_date
FROM
employees
ORDER BY
hire_date;

降序排列
SELECT
last_name,
job_id,
department_id,
hire_date
FROM
employees
ORDER BY
hire_date DESC;

按别名排序:
SELECT
employee_id,
last_name,
salary * 12 annsal
FROM
employees
ORDER BY
annsal;

多个列排序:按照ORDER BY 列表的顺序排序。
SELECT
last_name,
department_id,
salary
FROM
employees
ORDER BY
department_id,
salary DESC;

Oracle系列三 过滤和排序的更多相关文章
- Oracle系列(三): 情景查询一 a表中有个fid字段,逗号分隔开来,b表中有id字段及其他信息,如何关联a表的fid和和b表的id字段查询
现在有两个表,表a中 DOC FID 1 a,b,c 2 a,c,d 表b中 ID KEY a A b B c C d D 怎么联合查询出 DOC FID KEY 1 a,b,c A,B,C 2 a, ...
- oracle系列(三)表操作基础
支持的数据类型: 字符型char 定长 最大2000varchar2() 变长 最大4000clob 字符型大对象 最大4G 数字型number范围 -10的38次方到10的+38次方;number( ...
- 《Entity Framework 6 Recipes》中文翻译系列 (27) ------ 第五章 加载实体和导航属性之关联实体过滤、排序、执行聚合操作
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-9 关联实体过滤和排序 问题 你有一实体的实例,你想加载应用了过滤和排序的相关 ...
- Oracle Day2 过滤、排序、单行函数
1.过滤和排序 SQL> --查询10号部门的所有员工信息 SQL> select * from emp ; 未选定行 SQL> ed SP2: 无法创建保存文件 "afi ...
- Web 开发人员和设计师必读文章推荐【系列三十】
<Web 前端开发精华文章推荐>2014年第9期(总第30期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ...
- .Net程序员学用Oracle系列(11):系统函数(下)
1.聚合函数 1.1.COUNT 函数 1.2.SUM 函数 1.3.MAX 函数 1.4.MIN 函数 1.5.AVG 函数 2.ROWNUM 函数 2.1.ROWNUM 函数简介 2.2.利用 R ...
- .Net程序员学用Oracle系列(15):DUAL、ROWID、NULL
1.DUAL 表 2.ROWID 类型 2.1.利用 ROWID 查询数据 2.2.利用 ROWID 更新数据 3.NULL 值 3.1.NULL 与空字符串 3.2.NULL 与函数 3.3.NUL ...
- .Net程序员学用Oracle系列(30):零碎补充、最后总结(The End)
1.同义词 2.Flashback 技术 3.连接字符串的写法 4.转义字符 & 特殊运算符 5.文件类型 6.查看参数 & 修改参数 7.AWR 工具 8.学习方法 & 学习 ...
- Oracle01——基本查询、过滤和排序、单行函数、多行函数和多表查询
作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7272236.html Oracle的集群 Oracle的体系结构 SQL> --当 ...
随机推荐
- 02-CSS常用样式
本篇主要介绍css的常用样式,以及网页布局相关知识.绝对定位和相对定位,盒子模型.css权重.以及css选择器: 绪论:CSS基本介绍 为了让网页元素的样式更加丰富,也为了让网页的内容和样式能拆分开, ...
- Activity知识点详解
Activity知识点详解 一.什么是Activity 官方解释: The Activity class is a crucial component of an Android app, and t ...
- Kali下的内网劫持(四)
在前面我都演示的是在Kali下用命令行的形式将在目标主机上操作的用户的信息捕获的过程,那么接下来我将演示在Kali中用图形界面的ettercap对目标主机的用户进行会话劫持: 首先启动图形界面的ett ...
- moviepy的常见用法
看了,还是自己弄这些方便. #字幕 >>> from moviepy.video.tools.subtitles import SubtitlesClip >>> ...
- 云服务器CentOS7.4下搭建GitLab
一.Git.GitHub.GitLab的区别 Git是版本控制系统,Github是在线的基于Git的代码托管服务. GitHub是2008年由Ruby on Rails编写而成.GitHub同时提供付 ...
- C# 模拟鼠标移动和点击
我们需要用到的mouse_event函数,位于user32.dll这个库文件里面,所以我们要先声明引用. [System.Runtime.InteropServices.DllImport(" ...
- ARTS-week4
Algorithm 将两个有序链表合并为一个新的有序链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的.示例:输入:1->2->4, 1->3->4输出:1->1 ...
- windows——快速得到某一目录下所有文件的名称
前言 其实用的是windows上dir命令,能快速得到某一目录下的所有文件名称,天天那么忙都没时间写博客(┬_┬) 步骤 打开cmd并cd到某目录下 C:\Users\Administrator.KI ...
- PC端自适应布局
截止目前,国内绝大多数内容为主的网站(知乎,果壳,V2EX,网易新闻等)均使用内容区定宽布局,大多数电商网站(网易考拉,京东,聚美优品)也使用了内容区定宽的布局,也有些网站使用了自适应布局: 天猫 内 ...
- oracle中LPAD和RPAD函数的使用方法(加个人总结)
今天看到两个没有见过的SQL中的函数,总结一下: 函数参数:lpad( string1, padded_length, [ pad_string ] ) 其中 string1:源字符串 padded_ ...