当前位置:网站首页>SQL分类、DQL(数据查询语言)、以及相应SQL查询语句演示
SQL分类、DQL(数据查询语言)、以及相应SQL查询语句演示
2022-08-02 03:24:00 【cierxiao】
#博学谷IT学习技术支持#
文章目录
一、SQL分类
DDL(Data Definition Language) : 数据定义语言,用来定义数据库对象:数据库,表,列等
DDL简单理解就是用来操作数据库,表等
DML(Data Manipulation Language) 数据操作语言,用来对数据库中表的数据进行增删改
DML简单理解就对表中数据进行增删改
DQL(Data Query Language) 数据查询语言,用来查询数据库中表的记录(数据)
DQL简单理解就是对数据进行查询操作。从数据库表中查询到我们想要的数据。
DCL(Data Control Language) 数据控制语言,用来定义数据库的访问权限和安全级别,及创建用户
DCL简单理解就是对数据库进行权限控制。比如我让某一个数据库表只能让某一个用户进行操作等。
注意: 以后我们最常操作的是
DML
和DQL
,因为我们开发中最常操作的就是数据。
二、DQL
查询的完整语法:
SELECT
字段列表
FROM
表名列表
WHERE
条件列表
GROUP BY
分组字段
HAVING
分组后条件
ORDER BY
排序字段
LIMIT
分页限定
例子:为了给大家演示查询的语句,我先准备表及一些数据:
– 删除stu表
drop table if exists stu;
-- 创建stu表
CREATE TABLE stu (
id int, -- 编号
name varchar(20), -- 姓名
age int, -- 年龄
sex varchar(5), -- 性别
address varchar(100), -- 地址
math double(5,2), -- 数学成绩
english double(5,2), -- 英语成绩
hire_date date -- 入学时间
);
-- 添加数据
INSERT INTO stu(id,NAME,age,sex,address,math,english,hire_date)
VALUES
(1,'马运',55,'男','杭州',66,78,'1995-09-01'),
(2,'马花疼',45,'女','深圳',98,87,'1998-09-01'),
(3,'马斯克',55,'男','香港',56,77,'1999-09-02'),
(4,'柳白',20,'女','湖南',76,65,'1997-09-05'),
(5,'柳青',20,'男','湖南',86,NULL,'1998-09-01'),
(6,'刘德花',57,'男','香港',99,99,'1998-09-01'),
(7,'张学右',22,'女','香港',99,99,'1998-09-01'),
(8,'德玛西亚',18,'男','南京',56,65,'1994-09-02');
1.基础查询
1.1语法
查询多个字段
SELECT 字段列表 FROM 表名;
SELECT * FROM 表名; -- 查询所有数据
*不建议大家使用,因为在这写*不方便我们阅读sql语句
去除重复记录
SELECT DISTINCT 字段列表 FROM 表名;
起别名
AS: AS 也可以省略
1.2 练习
查询name、age两列
select name,age from stu;
查询所有列的数据,列名的列表可以使用*替代
select * from stu;
查询地址信息
select address from stu;
去除重复记录
select distinct address from stu;
查询姓名、数学成绩、英语成绩。并通过as给math和english起别名(as关键字可以省略)
select name,math as 数学成绩,english as 英文成绩 from stu; select name,math 数学成绩,english 英文成绩 from stu;
2.条件查询
2.1语法
SELECT 字段列表 FROM 表名 WHERE 条件列表;
条件
条件列表可以使用以下运算符
2.2 条件查询练习
查询年龄大于20岁的学员信息
select * from stu where age > 20;
查询年龄大于等于20岁的学员信息
select * from stu where age >= 20;
查询年龄大于等于20岁 并且 年龄 小于等于 30岁 的学员信息
select * from stu where age >= 20 && age <= 30; select * from stu where age >= 20 and age <= 30;
上面语句中 && 和 and 都表示并且的意思。建议使用 and 。
也可以使用 between … and 来实现上面需求
select * from stu where age BETWEEN 20 and 30;
查询入学日期在’1998-09-01’ 到 ‘1999-09-01’ 之间的学员信息
select * from stu where hire_date BETWEEN '1998-09-01' and '1999-09-01';
查询年龄等于18岁的学员信息
select * from stu where age = 18;
查询年龄不等于18岁的学员信息
select * from stu where age != 18; select * from stu where age <> 18;
查询年龄等于18岁 或者 年龄等于20岁 或者 年龄等于22岁的学员信息
select * from stu where age = 18 or age = 20 or age = 22; select * from stu where age in (18,20 ,22);
查询英语成绩为 null的学员信息
null值的比较不能使用 = 或者 != 。需要使用 is 或者 is not
select * from stu where english = null; -- 这个语句是不行的 select * from stu where english is null; select * from stu where english is not null;
2.3模糊查询练习
模糊查询使用like关键字,可以使用通配符进行占位:
(1)_ : 代表单个任意字符
(2)% : 代表任意个数字符
查询姓’马’的学员信息
select * from stu where name like '马%';
查询第二个字是’花’的学员信息
select * from stu where name like '_花%';
查询名字中包含 ‘德’ 的学员信息
select * from stu where name like '%德%';
3.排序查询
3.1语法
SELECT 字段列表 FROM 表名 ORDER BY 排序字段名1 [排序方式1],排序字段名2 [排序方式2] …;
上述语句中的排序方式有两种,分别是:
- ASC : 升序排列 (默认值)
- DESC : 降序排列
注意:如果有多个排序条件,当前边的条件值一样时,才会根据第二条件进行排序
3.2练习
查询学生信息,按照年龄升序排列
select * from stu order by age ;
查询学生信息,按照数学成绩降序排列
select * from stu order by math desc ;
查询学生信息,按照数学成绩降序排列,如果数学成绩一样,再按照英语成绩升序排列
select * from stu order by math desc , english asc ;
4.聚合函数
4.1概念
将一列数据作为一个整体,进行纵向计算。
4.2聚合函数分类
函数名 | 功能 |
---|---|
count(列名) | 统计数量(一般选用不为null的列) |
max(列名) | 最大值 |
min(列名) | 最小值 |
sum(列名) | 求和 |
avg(列名) | 平均值 |
4.3聚合函数语法
SELECT 聚合函数名(列名) FROM 表;
注意:null 值不参与所有聚合函数运算
4.4练习
统计班级一共有多少个学生
select count(id) from stu; select count(english) from stu;
上面语句根据某个字段进行统计,如果该字段某一行的值为null的话,将不会被统计。所以可以在count(*) 来实现。* 表示所有字段数据,一行中也不可能所有的数据都为null,所以建议使用 count(*)
select count(*) from stu;
查询数学成绩的最高分
select max(math) from stu;
查询数学成绩的最低分
select min(math) from stu;
查询数学成绩的总分
select sum(math) from stu;
查询数学成绩的平均分
select avg(math) from stu;
查询英语成绩的最低分
select min(english) from stu;
5.分组查询
5.1语法
SELECT 字段列表 FROM 表名 [WHERE 分组前条件限定] GROUP BY 分组字段名 [HAVING 分组后条件过滤];
注意:分组之后,查询的字段为聚合函数和分组字段,查询其他字段无任何意义
5.2练习
查询男同学和女同学各自的数学平均分
select sex, avg(math) from stu group by sex;
注意:分组之后,查询的字段为聚合函数和分组字段,查询其他字段无任何意义
select name, sex, avg(math) from stu group by sex; -- 这里查询name字段就没有任何意义
查询男同学和女同学各自的数学平均分,以及各自人数
select sex, avg(math),count(*) from stu group by sex;
查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组
select sex, avg(math),count(*) from stu where math > 70 group by sex;
查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组,分组之后人数大于2个的
select sex, avg(math),count(*) from stu where math > 70 group by sex having count(*) > 2;
where 和 having 区别:
- 执行时机不一样:where 是分组之前进行限定,不满足where条件,则不参与分组,而having是分组之后对结果进行过滤。
- 可判断的条件不一样:where 不能对聚合函数进行判断,having 可以。
6.分页查询
6.1语法
SELECT 字段列表 FROM 表名 LIMIT 起始索引 , 查询条目数;
注意: 上述语句中的起始索引是从0开始
6.2练习
从0开始查询,查询3条数据
select * from stu limit 0 , 3;
每页显示3条数据,查询第1页数据
select * from stu limit 0 , 3;
每页显示3条数据,查询第2页数据
select * from stu limit 3 , 3;
每页显示3条数据,查询第3页数据
select * from stu limit 6 , 3;
从上面的练习推导出起始索引计算公式:
起始索引 = (当前页码 - 1) * 每页显示的条数
总结
本篇文章内容主要介绍了 SQL分类、以及DQL的语法用法,附加了相关的查询语句的练习语句,可以极大程度地帮助我们掌握查询语句的用法,并根据用法逻辑判断出相应的应用情景,更有效率地帮助我们进行开发。
好啦!本篇文章到这里就结束啦!大家好好练习便能运用自如,每一天都要加油呀!!!
🥰 🥰 🥰你的点赞是对我最大的鼓励。🥰 🥰 🥰
🥰 🥰 🥰你的收藏是对我文章的认可。️🥰 🥰 🥰
🥰 🥰 🥰你的关注是对我前进的动力。🥰 🥰 🥰
边栏推荐
- querystring模块
- clock tick marks
- [Learning Records of Boxue Valley] Super summary, share with heart | Software Testing Interface Testing Basics
- 页面加载流程
- 6.27面试集
- Amazon sellers how to improve the conversion
- 3 minutes to take you to understand WeChat applet development
- C语言入门小游戏—三子棋
- Relative and absolute paths
- 语义分割标签即像素值的巨坑,transforms.ToTensor()的错误使用
猜你喜欢
C语言的变长数组
6.27面试集
Customer Rating Control
STM32 CAN过滤器
DOM manipulation---magnifying glass case
啃瓜记录第一天
ModuleNotFoundError No module named 'xxx' possible solutions
阿里云服务器如何使用admin账户登录
DSPE-PEG-PDP, DSPE-PEG-OPSS, phospholipid-polyethylene glycol-mercaptopyridine supply, MW: 5000
微信小程序自定义swiper轮播图面板指示点|小圆点|进度条
随机推荐
ES6迭代器解释举例
C语言 0长度数组/柔性数组
Amazon sellers how to improve the conversion
一分种一起来了解Vite的基础
枚举法方法:(leetcode1300)转变数组后最接近目标值的数组和
__dirname
每日五道面试题总结 22/7/26
Chemical reagent Phospholipid-polyethylene glycol-hydroxyl, DSPE-PEG-OH, DSPE-PEG-Hydroxyl, MW: 5000
URL模块
DSPE-PEG-DBCO Phospholipid-Polyethylene Glycol-Dibenzocyclooctyne A Linear Heterobifunctional Pegylation Reagent
clock tick marks
STM32 map文件解析
阿里云设置域名解析重定向后,无法使用Chrome访问
最新,每天填坑,Jeston TX1 精卫填坑,第一步:刷机
ThunderBirde无法登录问题、pycharm调试一直收集数据、RuntimeError: CUDA error: device-side assert triggered等疑难杂症解决
每日五道面试题 2022/7/27
The usage of json type field in mysql
display,visibility,opacity
每日五道面试题总结 22/7/21
如何根据地图上的两个坐标点来确定方向