数据库(四):DQL


DQL英文全称是Data Query Languaga(数据查询语言),用来查询数据库表中的记录。关键字 SELECT

在这里插入图片描述

新建表db_02(员工管理),并向表中写入数据。
数据准备:

-- 员工管理(带约束)
create table tb_emp (
    id int unsigned primary key auto_increment comment 'ID',
    username varchar(20) not null unique comment '用户名',
    password varchar(32) default '123456' comment '密码',
    name varchar(10) not null comment '姓名',
    gender tinyint unsigned not null comment '性别, 说明: 1, 2 女',
    image varchar(300) comment '图像',
    job tinyint unsigned comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管',
    entrydate date comment '入职时间',
    create_time datetime not null comment '创建时间',
    update_time datetime not null comment '修改时间'
) comment '员工表';

-- 准备测试数据
INSERT INTO tb_emp (id, username, password, name, gender, image, job, entrydate, create_time, update_time) VALUES
    (1, 'jinyong', '123456', '金庸', 1, '1.jpg', 4, '2000-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:35'),
    (2, 'zhangwuji', '123456', '张无忌', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:37'),
    (3, 'yangxiao', '123456', '杨逍', 1, '3.jpg', 2, '2008-05-01', '2022-10-27 16:35:33', '2022-10-27 16:35:39'),
    (4, 'weiyixiao', '123456', '韦一笑', 1, '4.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:41'),
    (5, 'changyuchun', '123456', '常遇春', 1, '5.jpg', 2, '2012-12-05', '2022-10-27 16:35:33', '2022-10-27 16:35:43'),
    (6, 'xiaozhao', '123456', '小昭', 2, '6.jpg', 3, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:45'),
    (7, 'jixiaofu', '123456', '纪晓芙', 2, '7.jpg', 1, '2005-08-01', '2022-10-27 16:35:33', '2022-10-27 16:35:47'),
    (8, 'zhouzhiruo', '123456', '周芷若', 2, '8.jpg', 1, '2014-11-09', '2022-10-27 16:35:33', '2022-10-27 16:35:49'),
    (9, 'dingminjun', '123456', '丁敏君', 2, '9.jpg', 1, '2011-03-11', '2022-10-27 16:35:33', '2022-10-27 16:35:51'),
    (10, 'zhaomin', '123456', '赵敏', 2, '10.jpg', 1, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:53'),
    (11, 'luzhangke', '123456', '鹿杖客', 1, '11.jpg', 2, '2007-02-01', '2022-10-27 16:35:33', '2022-10-27 16:35:55'),
    (12, 'hebiweng', '123456', '鹤笔翁', 1, '12.jpg', 2, '2008-08-18', '2022-10-27 16:35:33', '2022-10-27 16:35:57'),
    (13, 'fangdongbai', '123456', '方东白', 1, '13.jpg', 1, '2012-11-01', '2022-10-27 16:35:33', '2022-10-27 16:35:59'),
    (14, 'zhangsanfeng', '123456', '张三丰', 1, '14.jpg', 2, '2002-08-01', '2022-10-27 16:35:33', '2022-10-27 16:36:01'),
    (15, 'yulianzhou', '123456', '俞莲舟', 1, '15.jpg', 2, '2011-05-01', '2022-10-27 16:35:33', '2022-10-27 16:36:03'),
    (16, 'songyuanqiao', '123456', '宋远桥', 1, '16.jpg', 2, '2010-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:05'),
    (17, 'chenyouliang', '12345678', '陈友谅', 1, '17.jpg', null, '2015-03-21', '2022-10-27 16:35:33', '2022-10-27 16:36:07'),
    (18, 'zhang1', '123456', '张一', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:09'),
    (19, 'zhang2', '123456', '张二', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:11'),
    (20, 'zhang3', '123456', '张三', 1, '2.jpg', 2, '2018-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:13'),
    (21, 'zhang4', '123456', '张四', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:15'),
    (22, 'zhang5', '123456', '张五', 1, '2.jpg', 2, '2016-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:17'),
    (23, 'zhang6', '123456', '张六', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:19'),
    (24, 'zhang7', '123456', '张七', 1, '2.jpg', 2, '2006-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:21'),
    (25, 'zhang8', '123456', '张八', 1, '2.jpg', 2, '2002-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:23'),
    (26, 'zhang9', '123456', '张九', 1, '2.jpg', 2, '2011-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:25'),
    (27, 'zhang10', '123456', '张十', 1, '2.jpg', 2, '2004-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:27'),
    (28, 'zhang11', '123456', '张十一', 1, '2.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:29'),
    (29, 'zhang12', '123456', '张十二', 1, '2.jpg', 2, '2020-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:31');

在这里插入图片描述

一、基本查询

在这里插入图片描述

# 查询指定字段name,entrydata并返回
select name,entrydate from tb_emp;
# 查询所有返回字段
select id, username, password, name, gender, image, job, entrydate, create_time, update_time from tb_emp;
select * from tb_emp;
# 查询所有员工的name,entrydata,并起别名(如果别名中有特殊符号,就在别名外加单引号)
select name as 姓名,entrydate as 入职日期 from tb_emp;
select name 姓名,entrydate 入职日期 from tb_emp;
#查询已有的员工关联了哪几种职位不要重复
select distinct job from tb_emp;

注意:*号代表查询所有字段,在实际开发中尽量少用(不直观,影响效率)

二、条件查询

在这里插入图片描述
实例:

# 查询指定字段name,entrydata并返回
select name,entrydate from tb_emp;
# 查询所有返回字段
select id, username, password, name, gender, image, job, entrydate, create_time, update_time from tb_emp;
select * from tb_emp;
# 查询所有员工的name,entrydata,并起别名(如果别名中有特殊符号,就在别名外加单引号)
select name as 姓名,entrydate as 入职日期 from tb_emp;
select name 姓名,entrydate 入职日期 from tb_emp;
#查询已有的员工关联了哪几种职位不要重复
select distinct job from tb_emp;

# 条件查询
#查询名字为杨逍的员工
select * from tb_emp where name = '杨逍';
#查询id小于等于5的员工信息
select * from tb_emp where id<=5;
# 查询没有分配职位的员工信息
select * from tb_emp where job is null;
# 查询有分配职位的员工信息
select * from tb_emp where job is not null;
# 查询密码字段不是123456的员工
select * from tb_emp where password != '123456';
select * from tb_emp where password <> '123456';
#查询入职日期在2000-01-012010-01-01(包含)的员工
select *
from tb_emp where entrydate>='2000-01-01' and entrydate<='2010-01-01';

select * from tb_emp where entrydate between '2000-01-01' and '2010-01-01';

#查询入职日期在2000-01-012010-01-01(包含)的员工,并且性别为女的员工信息
select *
from tb_emp where entrydate>='2000-01-01' and entrydate<='2010-01-01' and gender=2;

# 查询职位为2 讲师 3学工主管 4教研主管
select * from tb_emp where job=2 or job=3 or job=4;
select * from tb_emp where job in (2,3,4);

#查询姓名为两个字的员工
select * from tb_emp where name like '__';

#查询姓名为三个字的员工
select * from tb_emp where name like '___';

#查询姓张的员工
select * from tb_emp where name like '张%';

三、分组查询

(一)聚合函数

在这里插入图片描述

(二)分组查询

在这里插入图片描述

#根据性别分组
select gender,count(*) from tb_emp group by gender;
#先查询 入职时间在'2015-01-01(包含)'以前的员工,并对结果根据职位进行分组,获取员工数量大于2的职位
select job,count(*) from tb_emp where entrydate<='2015-01-01' group by job having count(*)>=2;

问:where和having之后都是跟的查询条件,他们之间有什么不同
1、执行时机不同:where是在分组之前进行过滤,不满足where条件不参与分组,而having是对分组之后的结果进行过滤。
2、判断条件不同:where不能对聚合函数进行判断,而having可以。

分组查询的注意事项:分组之后,查询的字段一般为聚合函数和分组字段,查询其他字段无任何意义;执行顺序:where>聚合函数>having

四、排序查询

在这里插入图片描述
排序方式:ASC升序DESC降序

#根据入职时间进行生序排序
select * from tb_emp order by entrydate asc ;
select * from tb_emp order by entrydate ;

#根据入职时间进行降序排序
select * from tb_emp order by entrydate desc ;

#根据入职时间进行生序排序,如果入职时间相同,那么根据跟新时间进行降序排序
select * from tb_emp order by entrydate,update_time desc ;

注意事项:如果是多字段排序,当第一个字段值相同时,才会根据第二个字段排序。以此类推

五、分页查询

在这里插入图片描述

#从索引0开始 开始查询员工数据,每页展示五条记录
select * from tb_emp limit 0,5;
#从第一页开始 开始查询员工数据,每页展示五条记录
select * from tb_emp limit 0,5;
#从第二页开始 开始查询员工数据,每页展示五条记录
select * from tb_emp limit 5,5;
#从第三页开始 开始查询员工数据,每页展示五条记录
select * from tb_emp limit 10,5;
#起始索引 = (页码 - 1* 记录数

注意事项:
1、起始索引 = (页码 - 1)* 记录数
2、分页查询是数据库的方言,不同数据库分页有不同的实现
3、如果查询的是第一页的数据,起始索引可以省略。

六、案例

(一)员工管理的条件分页查询

根据输入的员工姓名、员工性别、入职时间搜索满足条件的员工信息。
其中员工姓名,支持模糊匹配;性别进行精确查询;入职时间进行范围查询。
支持分页查询。
册对查询的结果,根据最后修改时间进行倒序排序。

select *
from tb_emp where name like '%张%' and gender = 1 and entrydate between '2000-01-01' and '2015-12-31'
            order by update_time desc
            limit 10,10;

(二)根据需求完成员工性别、职位信息统计

#员工性别统计
select if(gender = 1,'男性员工','女性员工') as 性别,count(*) from tb_emp group by gender;
#员工职位信息
select (case job
    when 1 then '班主任'
    when 2 then '讲师'
    when 3 then '学工主管'
    when 4 then '教研主管'
    else '没有分配职位' end)
    as 职位,
       count(*)
from tb_emp group by job;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值