JavaWeb-27-数据库操作-DQL

数据库操作-DQL

一、DQL-概述-语法

1. 概述
  • DQL英文全称是Data Query Language(数据查询语言),用来查询数据库表中的记录
  • 关键字:SELECT

2. 语法结构

image-20230905153724572


3. 数据准备
-- DQL(数据查询语言)
-- 数据准备
# 1. 员工管理(带约束)
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 '员工表';

# 2. 准备测试数据
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');

image-20230905154923510



二、DQL-基本查询

1. 语法
  • 查询多个字段:

    select 字段1, 字段2, 字段3 from  表名;
    
  • 查询所有字段(通配符):

    select 字段1, 字段2, ..., 字段n from  表名;
    select *  from  表名;
    
  • 设置别名:

    • as可以省略
    select 字段1 [ as 别名1 ] , 字段2 [ as 别名2 ]  from  表名;
    
  • 去除重复记录:

    select distinct 字段列表 from  表名;
    

2. DQL操作
  • 查询多个字段:

    image-20230905160236510


  • 查询所有字段:

    image-20230905160516534

    image-20230905160642416


  • 起别名:

    image-20230905161008494


image-20230905161128456


  • 去除重复记录:

    image-20230905161307747


3. 注意事项

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



三、DQL-条件查询

1. 语法
  • 条件查询:

    select 字段列表 from  表名  where  条件列表 ;
    

2. 条件运算符
(1) 比较运算符
比较运算符功能
>大于
>=大于等于
<小于
<=小于等于
=等于
<> 或 !=不等于
between … and …在某个范围之内(含最小、最大值)
in(…)在in之后的列表中的值,多选一
like 占位符模糊匹配(_匹配单个字符, %匹配任意个字符)
is null是null
is not null不是null

(2) 逻辑运算符
逻辑运算符功能
and 或 &&并且 (多个条件同时成立)
or 或 ||或者 (多个条件任意一个成立)
not 或 !非 , 不是

3. DQL操作
  • 查询 姓名 为 杨逍 的员工

    image-20230905165816343


  • 查询 id小于等于5 的员工信息

    image-20230905165925454


  • 查询 没有分配职位 的员工信息

    image-20230905170001205


  • 查询 有职位 的员工信息

    image-20230905170043873


  • 查询 密码不等于 ‘123456’ 的员工信息

    image-20230905170115542


  • 查询 入职日期 在’2000-01-01’(包含) 到 ‘2010-01-01’(包含) 之间 的员工信息

    image-20230905170157360


  • 查询 入职日期 在’2000-01-01’(包含) 到 ‘2010-01-01’(包含) 之间 且 性别为女 的员工信息

    image-20230905170239128


  • 查询 职位是2(讲师), 3(学工主管), 4(教研主管) 的员工信息

    image-20230905170327726


  • 查询 姓名 为两个字的员工信息

    image-20230905170408691


  • 查询 姓’张’ 的员工信息

    image-20230905170439231



四、DQL-分组查询

1. 聚合函数
(1) 概述
函数功能
count统计数量
max最大值
min最小值
avg平均值
sum求和
  • 介绍:将一列数据作为一个整体,进行纵向计算。

(2) 语法
select 聚合函数(字段列表) from  表名;

(3) DQL操作
  • count

    image-20230906111814314


  • min

    image-20230906111911501


  • max

    image-20230906111947017


  • avg

    image-20230906112016890


  • sum

    image-20230906112042092


(4) 注意事项

注意事项:

  • null值不参与所有聚合函数的运算。

  • 统计数量可以使用:

    count(*)  count(非空字段)  count(常量),推荐使用count(*)
    


2. 分组查询
(1) 语法
select  字段列表  from   表名  [ where   条件 ]  group   by  分组字段名  [ having  分组后过滤条件 ];

(2) where与having区别(面试)

执行时机不同:where是分组之前进行过滤,不满足where条件,不参与分组;而having是分组之后对结果进行过滤。

判断条件不同:where不能对聚合函数进行判断,而having可以。


(3) DQL操作
  • 根据性别分组,统计男性和女性员工的数量

    image-20230906123707509

    image-20230906123746462


  • 先查询入职时间在 ‘2015-01-01’(包含) 以前的员工,并对结果根据 职位 分组,获取 员工数量大于等于2 的职位。

    • A. 先查询入职时间在 ‘2015-01-01’(包含) 以前的员工

      image-20230906124008861


    • B. 并对结果根据 职位 分组

      image-20230906124329681


    • C. 获取 员工数量大于等于2 的职位

      image-20230906125036978


(4) 注意事项
  • 分组之后,查询的字段一般为:聚合函数和分组字段,查询其他字段无任何意义

    image-20230906123707509

  • 执行顺序: where > 聚合函数 > having



五、DQL-排序查询

1. 语法
select  字段列表  from   表名   [ where   条件列表 ] [ group by  分组字段 ] order  by  字段1  排序方式1 , 字段2  排序方式2;

2.排序方式
  • ASC:升序(默认值)
  • DESC:降序

3. DQL操作
    1. 根据 入职时间,对员工进行 升序 排序

    image-20230906151304431


  • 2.根据 入职时间,对员工进行 降序 排序

    image-20230906151441594


  • 3.根据 入职时间 对公司的员工进行 升序 排序,入职时间相同,再按照 更新时间 进行降序排序

    image-20230906151925600


4. 注意事项
  • 如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序。


六、DQL-分页查询

1. 应用场景

image-20230906153104540


2. 语法
select  字段列表  from   表名  limit  起始索引, 查询记录数 ;

3. DQL操作
  • 1.从 起始索引0 开始查询员工数据,每页展示5条记录

    image-20230906153613158


  • 2.查询 第1页 员工数据,每页展示5条记录

    image-20230906154414086


  • 3.查询 第2页 员工数据,每页展示5条记录

    image-20230906154515756


  • 4.查询 第3页 员工数据,每页展示5条记录

    image-20230906154605381


4. 注意事项

① 起始索引从0开始,起始索引 = (查询页码 - 1)* 每页显示记录数

② 分页查询是数据库的方言,不同的数据库有不同的实现,MySQL中是LIMIT。

③ 如果查询的是第一页数据,起始索引可以省略,直接简写为 limit 10

image-20230906155005889



七、DQL-案例

1. 案例一
(1) 需求

image-20230906160518122

image-20230906161817128

  • 按需求完成员工管理的条件分页查询:
    • 输入条件:
      • 姓名:张(支持模糊匹配)
      • 性别:男(精确查询)
      • 入职时间:2000-01-01 ~ 2015-12-31(范围查询)
    • 根据输入条件,查询 第1页 数据,每页展示10条记录
    • 对查询的结果,根据 最后修改时间 进行倒序排序

(2) DQL操作
-- DQL: 案例
-- 案例1: 按需求完成员工管理的条件分页查询:
--    输入条件:
--      姓名:张 ; 性别:男 ; 入职时间:2000-01-01 ~ 2015-12-31
--    根据输入条件,查询 第1页 数据,每页展示10条记录
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;

image-20230906162515561



2. 案例二
(1) 需求
  • 根据需求,完成员工信息的统计:

    • 这类的需求也叫图形报表:做数据统计,将统计结果以可视化的形式展示

    image-20230906162834228

  • 分析:

    • 后端开发人员只需要写SQL进行统计,将统计结果返回给前端,前端再借助一些现成的报表组件库可以完成报表的渲染展示

(2) 流程控制函数
  • if(表达式, tvalue, fvalue):当表达式为true时,取值tvalue;当表达式为false时,取值fvalue
  • case 表达式 when value1 then result1 [when value2 then value2 …] [else result] end

(3) DQL操作
  • 案例2-1: 根据需求,完成员工性别信息的统计

    -- 案例2-1: 根据需求,完成员工性别信息的统计
    # 函数:if(条件表达式, true取值, false取值)
    select if(gender = 1, '男性员工', '女性员工') 性别, count(*) 员工数量 from tb_emp group by gender;
    

    image-20230906165226403


  • 案例2-2: 根据需求,完成员工职位信息的统计

    -- 案例2-2: 根据需求,完成员工职位信息的统计
    # 函数:case 表达式 when 值1 then 结果1 when 值2 then 结果2 ... else 结果 end
    select
           (case job when 1 then '班主任' when 2 then '讲师' when 3 then '学工主管' when 4 then '教研主管' else '未分配职位' end) 职位,
           count(*) 员工数量
    from tb_emp group by job;
    

    image-20230906170140508


(4) Apache ECharts
  • 后端写SQL语句统计好数据后,将统计结果返回给前端,前端再借助这个Apache ECharts现成的报表组件库可以完成报表的渲染展示
① 员工性别统计

image-20230906170812067


image-20230906171052194


image-20230906171835064


② 员工职位统计

image-20230906172527614


image-20230906172511635



总结

image-20230906172852366

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值