一、语法
select 查询列表
from 表名
where 筛选条件
二、筛选条件的分类
1、简单条件运算符
(大于) >、 < 、=、>=、 <=、 <=>(安全等于)、
<>
等价!=
(都表示不等于)
2、逻辑运算符
连接条件运算符
&&
and
||
or
!
not
3、模糊查询
like:一般搭配通配符使用,可以判断字符型或数值型
- 通配符:%任意多个字符,_任意单个字符
between and
①使用between and 可以提高语句的简洁度
②包含临界值
③两个临界值不要调换顺序
in
含义:判断某字段的值是否属于in列表中的某一项
特点:
- 使用in提高语句简洁度
- ②in列表的值类型必须一致或兼容
- ③in列表中不支持通配符
is null /is not null:用于判断null值
- =或<>不能用于判断null值
- is null或is not null 可以判断null值
三、案例
一、简单条件运算符:
- 案例1:查询工资>12000的员工信息
SELECT
*
FROM
employees
WHERE
salary > 12000;
结果:
- 案例2:查询部门编号不等于90号的员工名和部门编号
SELECT
last_name,
department_id
FROM
employees
WHERE
department_id<> 90;
结果
二、逻辑运算符筛选
- 案例1:查询工资z在10000到20000之间的员工名、工资以及奖金
SELECT
last_name,
salary,
commission_pct
FROM
employees
WHERE
salary > 10000 AND salary < 20000;
结果:
*案例2:查询部门编号不是在90到110之间,或者工资高于15000的员工信息
SELECT
*
FROM
employees
WHERE
NOT(department_id>=90 AND department_id<=110) OR salary>15000;
结果:
三、模糊查询
(1):like
- 案例1:查询员工名中包含字符a的员工信息
SELECT
*
FROM
employees
WHERE
last_name LIKE '%a%';
结果
1.like
特点:
①一般和通配符搭配使用
通配符:
- % 任意多个字符,包含0个字符
- _ 任意单个字符
- 案例2:查询员工名中第三个字符为n,第五个字符为l的员工名和工资
SELECT
last_name,
salary
FROM
employees
WHERE
last_name LIKE '__n_l%';
结果:
- 案例3:查询员工名中第二个字符为_的员工名
SELECT
last_name
FROM
employees
WHERE
# last_name LIKE '_\_%';
last_name LIKE '_$_%' ESCAPE '$';
这里涉及到了转移字符
\
,同时我们也可以通过 escape 自己定义转义字符
结果:
(2)between and
- 案例1:查询员工编号在100到120之间的员工信息
SELECT
*
FROM
employees
WHERE
employee_id >= 100 AND employee_id <= 120;
采用 between and
SELECT
*
FROM
employees
WHERE
employee_id BETWEEN 100 AND 120;
结果:
(3)in
案例:查询员工的工种编号是 IT_PROG、AD_VP、AD_PRES中的一个员工名和工种编号
SELECT
last_name,
job_id
FROM
employees
WHERE
job_id = 'IT_PROG'
OR job_id = 'AD_VP'
OR job_id = 'AD_PRES';
使用 in 关键字:
SELECT
last_name,
job_id
FROM
employees
WHERE
job_id IN ( 'IT_PROG', 'AD_VP', 'AD_PRES' );
结果:
(4)is null
- 案例1:查询没有奖金的员工名和奖金率
SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct IS NULL;
结果:
案例2:查询有奖金的员工名和奖金率
SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct IS NOT NULL;
结果:
补充
<=> (安全等于)
- 案例1:查询没有奖金的员工名和奖金率
SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct <=> NULL;
结果
- 案例2:查询工资为12000的员工信息
SELECT
*
FROM
employees
WHERE
salary <=> 12000;
结果
- IS NULL:仅仅可以判断NULL值,可读性较高,建议使用
- <=> :既可以判断NULL值,又可以判断普通的数值,可读性较低