一、排序查询
关键词 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的一个方言