摘要:条件查询;条件表达式,逻辑表达式,模糊查询,like,通配符,转义字符,escape关键字,between and,in,is null,is not null,安全等于。

条件查询
语法:

SELECT
查询列表
FROM
表名
WHERE
筛选条件;
1
2
3
4
5
6
我们根据筛选条件简单进行一下分类:

按条件表达式筛选
条件运算符:
>:大于
<:小于
=:等于
!=或<>:不等于
>=:大于或等于
<=:小于或等于

示例
查询工资大于12000的员工信息。
SELECT * FROM employees WHERE salary>12000;

查询部门编号不等于90号的员工名和部门编号。
SELECT
first_name,
department_id
FROM
employees
WHERE
department_id <> 90 ;
1
2
3
4
5
6
7

按逻辑表达式筛选
逻辑运算符:
逻辑运算符就是为了连接条件表达式。
&&或and:与
||或or:或
!或not:非

示例
查询工资在10000到20000之间的员工名、工资以及奖金率。
SELECT
first_name,
salary,
commission_pct
FROM
employees
WHERE
salary > 10000 && salary < 20000 ;
1
2
3
4
5
6
7
8

查询部门编号不是在90到110之间,或者工资高于15000的员工信息。
SELECT
*
FROM
employees
WHERE
NOT (department_id <= 110 AND department_id >= 90) OR salary > 15000;
1
2
3
4
5
6

模糊查询
模糊查询也是一种条件表达式,可以看做是一种复杂的条件表达式。
like
between and
in
is null或者is not null

我们逐个介绍一下:

1)like
like:意思就是“像是”。

一般和通配符搭配使用。
通配符有:
%:任意字符串,包含0个字符。
_:任意单个字符

如果我们要使用的字符就是“%”或者“_”,因为他们本身是通配符,所以我们要想使用它们作为字符,我们就需要转义字符:
\_:下划线
\%:百分号
当然前面的转义字符“\”不是强制要求的,我们也可以用关键字“ESCAPE”来自定义转义字符。这个我们可以在下面的第三个例子中看一下。

like用法示例
我们举一个例子,查询员工名中包含字符“a”的员工信息。
SELECT
*
FROM
employees
WHERE
first_name LIKE '%a%' ;
1
2
3
4
5
6

我们再举一个例子,查询员工名中第三个字符是“e”,第五个字符为“a”的员工的员工名和工资。
SELECT
first_name,
salary
FROM
employees
WHERE first_name LIKE '__e_a%' ;
1
2
3
4
5
6

第三个例子,**查询员工名中第二个字符是下划线“_”的员工的员工名和工资。**这里我们就需要用到上面介绍的转义字符。
SELECT
last_name,
salary
FROM
employees
WHERE
last_name LIKE '_\_%' ;
1
2
3
4
5
6
7

在一些特殊的情况下,我们也可以自定义转义字符,需要使用ESCAPE关键字。上面的例子,我们可以写成:
SELECT
last_name,
salary
FROM
employees
WHERE
last_name LIKE '_$_%' ESCAPE '$';
1
2
3
4
5
6
7
这样我们就定义了$作为我们的转义字符。我们可以看到效果是一样的。

2)between and
between and:意思就是“在什么之间”。

我们举一个例子:查询员工编号在100到120之间的员工信息。
这里的条件我们通常写成employee_id >= 100 AND employee_id <= 120。
我们也可以使用between and,between and语句和上面的一句是等效的,这样我们就可以写成

SELECT
*
FROM
employees
WHERE
employee_id BETWEEN 100 AND 120 ;
1
2
3
4
5
6
也可以达成相同的效果:

但是我们要注意几点:

使用between and可以大大提高sql语句的简洁度;
包含临界值,例如上面的例子中,是包含100和120的
前后顺序不可以颠倒!这一点很重要,如果写成between 120 and 100,这样不会报错,但是不会有结果。
3)in
in的意思就是“在……里面”。

我们也是先举一个例子:查询员工的工种编号是IT_PROG、AD_VP、AD_PRES中的任意一个的员工的员工名和工种编号。
我们可以使用逻辑运算符OR,可以写成:

job_id = 'IT_PROG' OR job_id = 'AD_VP' OR job_id = 'AD_PRES';
1
我们也可以使用IN写成:

SELECT
last_name,
job_id
FROM
employees
WHERE job_id IN ('IT_PROG', 'AD_VP', 'AD_PRES') ;
1
2
3
4
5
6
我们看一下结果:

我们介绍一下IN的特点:

IN 的作用就是判断某字段的值是否属于IN列表中的某一项。
使用IN可以提高SQL语句的简洁度。
IN列表的值类型必须一致或者兼容。
在IN列表中是不支持通配符的。所有字符都将被当做字符本身来处理。
4)is null 和is not null
is null和is not null:判断是否为空值。

我们先举一个例子,我们要查询一下没有奖金的员工的员工名和奖金率。
这时我们要使用is null或者 is not null:

SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct IS NULL ;
1
2
3
4
5
6
7

那么请问我们可以使用commission_pct = NULL吗?
答案是不可以的。

而且要注意的是IS NULL是一个整体,IS只能用于NULL值得判断,不可以做其他的判断。

补充:安全等于
最后我们补充一下SQL里面的“安全等于”,符号是“<=>”

安全等于是可以判断null值的。
当然也可以用于普通数值的判断,与“=”一样。
但是安全等于用的很少,因为它的可读性比较差。所以还是建议使用普通的“=”或者“IS NULL”。

例如上面判断奖金是否为null的例子,我们在条件表达式就可以写成:

SELECT
last_name,
commission_pct
FROM
employees
WHERE
commission_pct <=> NULL ;
1
2
3
4
5
6
7
上面判断查询员工工资为12000的例子中,可以写成

SELECT
*
FROM
employees
WHERE
salary <=> 12000 ;
1
2
3
4
5
6

---------------------

MySQL(四)DQL语言——条件查询的更多相关文章

  1. MySQL的DQL语言(查)

    MySQL的DQL语言(查) DQL:Data Query Language,数据查询语言. DQL是数据库中最核心的语言,简单查询,复杂查询,都可以做,用select语句. 1. 查询指定表的全部字 ...

  2. MySql(四)Select条件查询

    select条件查询的格式如下: SELECT 查询列表FROM 表名WHERE 筛选条件:123456根据筛选条件可以分为以下几类: 按照条件按表达式进行筛选 常用条件运算符如下:> .< ...

  3. mysql四-1:单表查询

    一 单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数 二 关键 ...

  4. Mysql(四)-1:单表查询

    一 单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数 二 关键 ...

  5. Python、mysql四-1:单表查询

    一 单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数 二 关键 ...

  6. mysql增删改查——条件查询+模糊查询

    条件查询一般是 = 等于 >大于 <小于 >=大于等于 <=小于等于 <>区间 between and区间 or并且 and或者 in包含 like模糊查询 实例, ...

  7. mysql根据分组和条件查询以后如何统计记录的条数

    1.子查询,查询出的数据随便起一个别名,然后根据分组和条件查询出的数据,作为一个具有一列的一个表,然后外面的查询查询这个数据表的这一列的总数,即可. SELECT COUNT( * ) FROM ( ...

  8. mysql四-2:多表查询

    一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 准备表 #建表 create table department( id int, name varchar(20) ); create ta ...

  9. Mysql(四)-2:多表查询

    一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 准备表 #建表 create table department( id int, name varchar(20) ); create ta ...

随机推荐

  1. python可变參数调用函数问题

    一直使用python实现一些想法,近期在使用python的过程中出现这样一个需求,定义了一个函数.第一个是普通參数.第二个是默认參数,后面还有可变參数,在最初学习python的时候,都知道非keywo ...

  2. iOS8使用TouchID

    iOS8新增了LocalAuthentication框架,用于TouchID的授权使用.亲測,眼下须要用户的设备支持指纹识别并已设置锁屏,并且实际測试过程中反馈比較慢.不能直接跟第三方账号passwo ...

  3. 卷积神经网络-进化史】从LeNet到AlexNet

    目录视图 摘要视图 订阅 [置顶] [卷积神经网络-进化史]从LeNet到AlexNet 标签: cnn 卷积神经网络 深度学习 2016年05月17日 23:20:3046038人阅读 评论(4)  ...

  4. [Java] 监控java对象回收的原理与实现

    监控Java对象回收的原理与实现 一.监控Java对象回收的目的 监控Java对象是否回收的目的是:为了实现内存泄露报警. 内存泄露是指程序中对象生命周期(点击查看详情)已经进入不可见阶段,但因为编码 ...

  5. Python获取CPU、内存使用率以及网络使用状态代码

    Python获取CPU.内存使用率以及网络使用状态代码_python_脚本之家 http://www.jb51.net/article/134714.htm

  6. TFLearn 在给定模型精度时候提前终止训练

    拿来主义:看我的代码,我是在模型acc和验证数据集val_acc都达到99.8%时候才终止训练. import numpy as np import tflearn from tflearn.laye ...

  7. HTTPS数据包抓取的可行性分析

    HTTPS数据包抓取的可行性分析 相信只要是从事软件开发, 多多少少都会涉及到数据包的抓取.常见的有网页数据抓取(即网页爬虫),应用程序数据包抓取等.网页数据抓取比较简单, 在chrome下可以非常方 ...

  8. bzoj3196 二逼平衡树——线段树套平衡树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3196 人生中第一棵树套树! 写了一个晚上,成功卡时 9000ms+ 过了! 很要注意数组的大 ...

  9. Face alignment at 3000FPS via Regressing Local Binrary features 理解

    这篇是Ren Shaoqing发表在cvpr2014上的paper,论文是在CPR框架下做的,想了解CPR的同学可以参见我之前的博客,网上有同学给出了code,该code部分实现了LBF,链接为htt ...

  10. centOS命令随笔记(杂):cd、pwd

    1.向上向下翻页: 反向的命令一般是Shift-PageUp和Shift-PageDown. 每日一命令:cd 1.cd /   进入系统根目录 2.cd ..   进入系统根目录可以使用“ cd . ...