Skip to main content

Command Palette

Search for a command to run...

MySQL | 条件查询的语句(一)

Published
3 min read
MySQL | 条件查询的语句(一)

数据操作语言:条件查询(一)

条件查询

  • 很多时候,用户感兴趣的并不是逻辑表里的全部记录,

    而只是他们当中能够满足某一种或某几种条件的记录。这类条件要用 WHERE 子句来实现数据的筛选

SELECT ...... FROM ..... WHERE 条件 [AND | OR] 条件 ...... ;

07

SELECT empno,ename,sal
FROM t_emp
WHERE deptno=10 AND sal>=2000;
WHERE (deptno=10 OR deptno=20)AND sal>=2000;

四类运算符

  • WHERE 语句中的条件运算会用到以下四种运算符:
序号运算符
1数学运算符
2比较运算符
3逻辑运算符
4按位运算符

算数运算符

序号表达式意义例子
1+加法1 + 2 + 3
2-减法1 - 2 - 3
3*乘法5 * 35
4/除法231 / 15
5%求模10 % 3

查询 10 部门里面 年收入超过 15K 美金,并且工龄超过二十年 的员工信息

SELECT empno,ename,sal,hiredate
FROM t_emp
WHERE deptno=10 AND (sal+IFNULL(comm,0))*12>=15000;
AND DATEDIFF(NOW(),hiredata)/265>=20;

-- 获取当前日期
SELECT NOW()
-- 引入一个新函数 IFNLL 若第一个参数为 NULL 则返回第二个参数
SELECT 10+IFNULL(null,0);

比较运算符(一)

序号表达式意义例子
1>大于age > 18
2>=大于等于age >= 18
3<小于sal < 3000
4<=小于等于sal <= 3000
5=等于deptno = 10
6!=不等于deptno != 30
7IN包含deptno IN(10,30,40)

查询 10,20,30 部门里面,在 1985 年以前入职的员工并且不是 saselmen 员工的信息

SELECT 
    empno,ename,sal,deptno,hiredate
FROM t_emp
WHERE deptno IN(10,20,30) AND job!="SALESMAN"
AND hiredate<"1985-01-01";

比较运算符(二)

序号表达式意义例子
8IS NULL为空comm IS NULL
9IS NOT NULL不为空comm IS NOT NULL
10BETWEEN AND范围sal BETWEEN 2000 AND 3000
11LIKE模糊查询ename LIKE "A%"
12REGEXP正则表达式ename REGEXP "[a-zA-Z]{4}"
SELECT 
ename,comm,sal
FROM t_emp WHERE comm IS NOT NULL
SELECT 
    ename,comm,sal
FROM t_emp WHERE comm IS NULL
AND sal BETWEEN 2000 AND 3000;
SELECT 
    ename,comm,sal
FROM t_emp WHERE comm IS NULL
AND sal BETWEEN 2000 AND 3000
AND ename LIKE "%A%";
SELECT 
    ename,comm,sal
FROM t_emp WHERE comm IS NULL
AND sal BETWEEN 2000 AND 3000
AND ename LIKE "_LAKE";
-- _ 运算符
SELECT 
    ename,comm,sal
FROM t_emp WHERE comm IS NOT NULL
AND sal BETWEEN 1000 AND 3000
AND ename REGEXP "^[\\u4e00-\\u9fa5]{2,4}$";
-- 两到四个字符的中文
7 views

More from this blog

MySQL | 表的内连接

数据操作语言:表连接查询(一) 从多张表中提取数据 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积。 规定了连接条件的表连接语句,就不会出现笛卡尔积。 # 查询每名员工的部门信息 SELECT e.empno,e.ename,d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno; 表连接的分类 表连接分为两种:内连接 和 外连接 内连接是结果集中只保留符合...

May 16, 20221 min read13
MySQL | 表的内连接

MySQL | 分组查询的应用

数据操作语言:分组查询 为什么要分组? 默认情况下汇总函数是对全表范围内的数据做统计 GROUP BY 子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理 SELECT deptno,AVG(sal) FROM t_emp GROUP BY deptno; SELECT deptno,ROUND(AVG(sal)) FROM t_emp GROUP BY deptno; -- ROUND 取整 逐级分组 数据库支持多列分组条件,执行的时候...

Apr 27, 20221 min read10
MySQL | 分组查询的应用

MySQL | 聚合函数的使用

数据操作语言:聚合函数 什么是聚合函数 聚合函数在数据的查询分析中,应用十分广泛。聚合函数可以对 数据求和、求 最大值 和 最小值 、求 平均值 等等。 求公司员工的评价月收入是多少? SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp; SELECT AVG(sal+IFNULL(comm,0)) AS avg FROM t_emp; SUM 函数 SUM 函数用于求和,只能用户数字类型,字符类型的统计结果为 0 ,日期类型统计结果是毫秒数相加 SE...

Apr 26, 20221 min read8
MySQL | 聚合函数的使用
U

Untitled Publication

173 posts