MySQL_DQL之单表查询 ( 排序查询、聚合查询、分组查询 、分页查询 )

一、排序查询

关键词 ORDER BY

-- 按数学成绩进行排序--默认是升序的
SELECT * FROM student ORDER BY math ASC;

-- 降序
SELECT * FROM student ORDER BY math DESC;

-- 按照数学成绩排名,如果数学成绩一样,则按照英语成绩排名
SELECT * FROM student ORDER BY math DESC,english DESC;

二、聚合查询

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

聚合函数的计算会排除非空的

1、选择不包含非空的列进行计算(主键)
2、采用 IFNULL(列名 , 0) 的函数

count 计算个数

-- count 计算个数
SELECT COUNT(NAME)FROM student;

-- 计算所用变量
SELECT COUNT(*)FROM student;


max 计算最大值

-- 计算数学成绩最大值
SELECT MAX(math) FROM student;

min 计算最小值

-- 计算数学成绩最小值
SELECT MIN(math) FROM student;

sum 求和

-- 求和
SELECT SUM(math)FROM student;

avg 计算平均值

-- 求平均值
SELECT AVG(math)FROM student;

三、分组查询

分组之后加分组的字段和聚合函数
加其他的字段是没有意义的

-- 按性别分组,分别查询男女同学的平均分
SELECT sex, AVG(english) FROM student GROUP BY sex;
-- 按性别分组,分别查询男女同学的平均分,人数
SELECT sex, AVG(math),AVG(english),COUNT(id) FROM student GROUP BY sex;

Where 和 Having 的区别

-- 按性别分组,分别查询男女同学的平均分,人数,要求:分数低于70分的人不参与分组
SELECT sex, AVG(math),COUNT(id)AS 人数 FROM student WHERE math>70 GROUP BY sex;

-- 按性别分组,分别查询男女同学的平均分,人数,要求:分数低于70分的人不参与分组,分组之后,人数要大于3个人
SELECT sex, AVG(math),COUNT(id)AS 人数 FROM student WHERE math>70 GROUP BY sex HAVING COUNT(id)>3;

1、Where 在分组之前进行限定,如果条件不满足,则不参与分组。Having 是在分组之后进行限定, 如果不满足结果则不会被查询出来。

2、where后不可以跟聚合函数,Having可以进行聚合函数的判断。

四、分页查询

语法 : limit 开始的语法,每页查询的条数;

公式 : 开始的索引 = (当前页码 - 1)* 每页显示的条数;

-- 每页显示三条
SELECT *FROM student LIMIT 0,3;-- 第一页

SELECT *FROM student LIMIT 3,3;-- 第二页

SELECT *FROM student LIMIT 6,3;-- 第三页

SELECT *FROM student LIMIT 9,3;-- 第四页

分页操作是一个“方言”
limit 是MySQL的一个方言


版权声明:本文为weixin_46441425原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。