2)修改数据【UPDATE】
3)删除数据【DELETE】
添加数据
修改数据
删除数据
DQL
数据查询语言,用来查询数据库表中记录。关键字SELECT
图片
PART01
语法
语法
/*
SELECT
字段列表
FROM
表名列表
WHERE
条件列表
GROUP BY
分组字段列表
HAVING
分组后条件列表
ORDER BY
排序字段列表
LIMIT
分页参数
*/
基础查询
# 查询多个字段语法 SELECT 字段1, 字段2, 字段3 ... FROM 表名 ;
# 查询所有字段语法 SELECT * FROM 表名 ;
# 例
SELECT name,age FROM emp;
SELECT * FROM emp;
# * 代表查询所有字段,影响效率,开发中不推荐使用
# 设置别名语法 SELECT 字段1 [ AS 别名1 ] , 字段2 [ AS 别名2 ] ... FROM 表名;
# 简写形式 SELECT 字段1 [ 别名1 ] , 字段2 [ 别名2 ] ... FROM 表名;
# 例
SELECT name AS ename,workno no,age FROM emp;
# 去除重复记录语法 SELECT DISTINCT 字段列表 FROM 表名;
# 例
select distinct workaddress '工作地址',dep_id from emp;
# 注:distinct是对当前记录去重,当distinct后面跟多个字段时,去重条件为这几个字段的值
条件拆查询
语法
SELECT 字段列表 FROM 表名 WHERE 条件列表 ;
案例
# 查询年龄等于 88 的员工
select * from emp where age = 88;
# 查询年龄小于 20 的员工信息
select * from emp where age < 20;
# 查询年龄小于等于 20 的员工信息
select * from emp where age <= 20;
# 查询没有身份证号的员工信息
select * from emp where idcard is null;
# 查询有身份证号的员工信息
select * from emp where idcard is not null;
# 查询年龄不等于 88 的员工信息
select * from emp where age != 88;
# 查询年龄在15岁(包含) 到 20岁(包含)之间的员工信息
select * from emp where age >= 15 && age <= 20;
# 查询性别为 女 且年龄小于 25岁的员工信息
select * from emp where gender = '女' and age < 25;
# 查询年龄等于18 或 20 或 40 的员工信息
select * from emp where age = 18 or age = 20 or age =40;
select * from emp where age in(18,20,40);
# 查询姓名为两个字的员工信息 _ %
select * from emp where name like '__';
# 查询身份证号最后一位是X的员工信息
select * from emp where idcard like '%X';
select * from emp where idcard like '_________________X';
聚合函数
语法
SELECT 聚合函数(字段列表) FROM 表名 ;
常见聚合函数
案例
# 统计该企业员工数量
select count(*) from emp; -- 统计的是总记录数
select count(idcard) from emp; -- 统计的是idcard字段不为null的记录数
#对于count聚合函数,统计符合条件的总记录数,还可以通过 count(数字/字符串)的形式进行统计查询,比如:
select count(1) from emp;
/* 对于count(*) 、count(字段)、 count(1) 的具体原理,我们在进阶篇中SQL优化部分会详
细讲解,此处大家只需要知道如何使用即可*/。
#统计该企业员工的平均年龄
select avg(age) from emp;
# 统计该企业员工的最大年龄
select max(age) from emp;
# 统计该企业员工的最小年龄
select MIN(age) from emp;
# 统计西安地区员工的年龄之和
select sum(age) from emp where workaddress = '西安';
分组查询
语法
SELECT 字段列表 FROM 表名