MySQL数据库之单表查询(详)

首先创建数据库,准备数据:

-- 员工管理(带约束)
drop table if exists tb_emp;
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 not null comment '性别, 说明: 1 男, 2 女',
    image varchar(300) comment '图像',
    job tinyint 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');

基本操作:

1. 查询指定代码字段: select 字段1, 字段2, 字段3... from 表名

2. 查询所有字段: select * from 表名

3. 设置别名: select 字段1 as 别名, 字段2 as 别名, 字段3 as 别名... from 表名

4. 去除重复记录: select distinct 字段列表 from 表名

-- 查询所有 select * from 表名
select * from tb_emp;

-- 1. 查询指定字段 name,entrydate 并返回
select name, entrydate from tb_emp;

-- 3. 查询所有员工的 name,entrydate, 并起别名(姓名、入职日期)  --- as 关键字可以省略
select name as 姓名, entrydate as 入职日期 from tb_emp;
select name 姓名, entrydate 入职日期 from tb_emp;	--别名不能包含空格,如果空格使用单引号扩住

-- 4. 查询员工有哪几种职位(不要重复)
select distinct job from tb_emp;

条件查询:

--条件查询: select  字段列表  from   表名   where   条件列表 ;

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

-- 1-1. 查询 姓名 为 杨逍 的员工
select * from tb_emp where name = '杨逍';

-- 1-2. 查询在 id小于等于5 的员工信息
select * from tb_emp where id < 5;

-- 1-3. 查询 密码不等于 '123456' 的员工信息
select * from tb_emp where password != '123456';
select * from tb_emp where password <> '123456';

-- 1-4. 查询 没有分配职位 的员工信息
select * from tb_emp where job is null;

-- 1-5. 查询 有职位 的员工信息
select * from tb_emp where job is not null;

-- 2-1. 查询 id<=5 并且 job=2  的员工信息
select * from tb_emp where id<=5 and job = 2;

-- 2-1. 查询 id<=5 或者 job=2  的员工信息
select * from tb_emp where id<=5 or job=2;

-- 3-1. 查询入职日期 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间的员工信息
select * from tb_emp where entrydate between '2000-01-01' and '2010-01-01';
select * from tb_emp where entrydate>= '2000-01-01' and entrydate<= '2010-01-01';

-- 3-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);

-- 4-1. 查询姓 '张' 的员工信息
select * from tb_emp where name like '张%';

-- 4-2. 查询姓名中包含 '三' 的员工信息
select * from tb_emp where name like '%三%';

-- 4-3. 查询姓'张',并且姓名为三个字的员工信息
select * from tb_emp where name like '张__';

聚合函数:

聚合函数:  将一列数据作为一个整体,进行纵向计算,

语法为: select 聚合函数(字段名) from 表名

函数功能
count统计数量
max最大值
min最小值
avg平均值
sum求和
-- 1. 统计该企业员工数量
select count(*) from tb_emp;
select count(id) from tb_emp; -- 不包含空值的列
select count(1) from tb_emp; -- 任意数字

-- 2. 统计该企业最早入职的员工的入职日期
select min(entrydate) from tb_emp;

-- 3. 统计该企业最迟入职的员工的入职日期
select max(entrydate) from tb_emp;

-- 4. 统计该企业员工ID的平均值
select avg(id) from tb_emp;

-- 5. 统计该企业员工的ID之和
select sum(id) from tb_emp;

分组过滤:

分组过滤: select 分组字段, 聚合函数() from 表名 group by 分组字段名 having 分组后过滤条件

-- 1. 根据性别分组, 统计男性和女性员工的数量
select gender count(*) from tb_emp group by gender; 

-- 2. 先查询入职时间在 '2015-01-01' (包含) 以前的员工
select * from tb_emp where entrydate <= '2015-01-01';

-- 3. 先查询入职时间在 '2015-01-01' (包含) 以前的员工,并对结果根据职位分组
select job, count(1) from tb_emp where entrydate <= '2015-01-01' group by job;

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

排序:

排序:  select 字段列表 from 表名 order by 字段1 排序方式1 , 字段2 排序方式2, ...

ASC:升序(默认值)

DESC:降序

-- ------------------------排序
-- 1. 根据入职时间,对员工进行降序排序
select * from tb_emp order by entrydate desc;

-- 2. 根据入职时间,对员工进行升序排序
select * from tb_emp order by entrydate asc;
select * from tb_emp order by entrydate;				-- 默认排序方式为升序 asc

-- 3. 根据入职时间对公司的员工进行升序排序,入职时间相同再按照ID进行降序排序
select * from tb_emp order by entrydate asc, id desc;

分页:

分页: select 字段列表 from 表名 limit 起始索引, 查询记录数

-- 第一页 startIndex=0, pageSize=3
select * from tb_emp limit 0,3;
-- 第二页 startIndex=3, pageSize=3
select * from tb_emp limit 3,3;
-- 第三页 startIndex=6, pageSize=3
select * from tb_emp limit 6,3;
-- 第page页 startIndex=(page-1)*pageSize, pageSize=3
-- select * from tb_emp limit (page-1)*pageSize ,3;

总结

select distinct 字段列表 | * 
from 表名
where 查询条件
group by 分组字段
	having 分组过滤条件
order by 排序字段 排序方式, ...
limit 开始索引,每页个数
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值