一、条件查询
1、含义:前面学的基础查询可以查询一个或多个字段,如果需要的数据仅仅是其中的某一行或多行就用到了条件查询。
2、语法:(序号表示语句执行顺序)
SELECT 字段名 ③
FROM 表名 ①
WHERE 筛选条件; ②
3、筛选条件
#1条件运算符:
> < = <> >= <=
#2逻辑运算符:
&& || !
#3模糊查询:
like、between and、in、is null
案例一:查询所有员工中工资大于10000的员工名、工资(条件运算符+起别名+点语法)
SELECT last_name,salary
FROM employees e #起别名
WHERE e.`salary`>10000; #点语法访问表中的字段
注意:在from中给表employees起别名后where中再使用employees.salary是错误的
案例二:查询所有员工中工资大于5000并且部门编号大于105的员工信息(逻辑运算符+起别名)
SELECT *
FROM employees e
WHERE e.`salary`>5000 && e.`department_id`>105;
注意:MySQL中支持&&但推荐使用 AND、OR分别代替&&、||
案例三:查询所有员工中姓名第二个字母位'k'且工资在1000到20000之间的员工信息(模糊查询)
SELECT *
FROM employees e
WHERE e.`last_name` LIKE '_k%' AND e.`salary` BETWEEN 1000 AND 20000;
补充:
1、通配符:(使用like的模糊查询中用到)
①'%'在通配符中代表任意长度任意字符,其中任意长度可为0
②'_'在通配符中代表长度为1的任意字符
③如果要查询的字段中包含'%'、'_' 可以使用转义符'\'或自定义转义符,例如:
案例:查询员工姓名中包含'_'的员工信息
//使用'\'作为转义符(默认)
SELECT *
FROM employees e
WHERE e.`last_name` LIKE '%\_%' ;
//自定义转义符,使用escape关键字
SELECT *
FROM employees e
WHERE e.`last_name` LIKE '%$_%' ESCAPE '$';
2、between ... and ... :
①两者之间均可满足(不可等于临界值)
②between numa and numb,numa与numb的位置不可交换即必须满足:numa<=numb
3、模糊查询(in):
语法:
last_name in('a','b','c');
注意:
①括号中多个元素在一起时逗号隔开
②当last_name与括号中至少一个字符串完全一直时才会被筛选出来
4、模糊查询(is null):
语法:
last_name is null;
注意:MySQL中不能直接使用 ' == '来判空,但使用安全等于' <=> ' 可判空也可判定其它任意类型的数据
二、排序查询
1、含义:排序查询可将查询出的数据按照特定字段的数值按由小到大或由大到小排序。
2、语法:(执行顺序如序号所示)
SELECT 字段名 ④
FROM 表名 ①
【WHERE 筛选条件】 ②
ORDER BY 排序方式; ③
注意:
①排序方式分为两种ASC(升序)、DESC(降序)
②OREDER BY子句一般在查询语句的最后面,除了limit子句
案例:查询全体员工中薪资大于8000的员工姓名并将薪资按升序排列(排序查询+起别名)
SELECT last_name,salary
FROM employees e
WHERE e.`salary`>8000
ORDER BY e.`salary` ASC;
三、分组查询
1、单行函数:
①字符函数:
SELECT LENGTH('hello world!'); 返回括号中所占总字节数(多数函数返回字符数,仅该函数返回字节数)
SELECT CONCAT('str1','str2','str3'); 将括号中多个字符串拼接成一个长的字符串
SELECT UPPER('str'),LOWER('STR'); 变大、小写
SELECT SUBSTR('str',a,b); 在str中从第a位开始截取长度为b的字符串(第一个字符索引为1)
SELECT REPLACE('str','str1','str2');将str中的str1全部替换为str2
②数学函数
SELECT ROUND(1.345,2); 将1.345保留2位小数的四舍五入
SELECT CEIL(0.9),FLOOR(1.1); 将0.9向上取整,将1.1向下取整
SELECT TRUNCATE(1.55555,2); 保留两位小数
SELECT MOD(10,9); 取余(10%9)
③日期函数
SELECT NOW(); 打印当前时间
SELECT DATE_FORMAT(NOW(),'%Y年%m月%d日'); 将标准日期类型(datetime)的数据转化为字符串(varchar)
SELECT STR_TO_DATE('1998-3-2','%Y-%c-%d') AS out_put; 将字符串(varchar)转化为指定日期类型
④流程控制函数(只举一例if函数)
SELECT IF(3>2,end1,end2); 当3>2成立时,执行end1,否则执行end2
2、分组函数
求和:sum()、均值:avg()、最大值:max()、最小值:min()、求数目:count()、求日期差(天):datediff()
注意:用法在下面的分组查询中会详细讲解
3、分组查询
1、含义:题目中出现’ 每个 ‘的时候一般要使用分组查询,即:将整个表的数据按某个性质分成n组(理解不了就直接看案例)
2、语法:
SELECT 字段名或分组函数
FROM 表名
【WHERE 筛选条件】
GROUP BY 分组依据
ORDER BY 排序方式
案例一:查询每个部门的最低工资(起别名+分组排序)
理解:题中出现每个,要用分组排序,查询每个部门的最低工即:先将所有人按部门编号分成多组,再从每组中选出最低工资
SELECT MIN(salary) 最低工资,department_id 部门编号
FROM employees
GROUP BY department_id;
运行结果:
案例二:查询每个管理者手下员工的最低工资,并且最低工资不能低于6000,没有管理者的员工不计算在内
题目比较复杂分两步做:
①按照manage_id分组,从中选出最低工资
SELECT MIN(salary),manager_id
FROM employees
WHERE manager_id IS NOT NULL
GROUP BY manager_id;
②筛选最低工资大于等于6000的数据
SELECT MIN(salary),manager_id
FROM employees
WHERE manager_id IS NOT NULL
GROUP BY manager_id
HAVING MIN(salary)>=6000;
注意:既然也是筛选为什么用的时having?
where筛选与having筛选的区别:分组前筛选用where,分组后筛选用having。
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
复习整理,如有错误请指出。