MYDQL排序 限制查询 聚合函数 分组查询2018-08-10
升序排列
SELECT 列,列 FROM 表 ORDER BY 列 ASC;
降序排列
SELECT 列,列 FROM 表 ORDER BY 列 DESC;
多列排序
SELECT 列,列 FROM 表 ORDER BY 列 ASC,列 DESC;
首先按照第一个列排序在第一个列有相同情况下在按照第二个列排序
查询出性别为0的学生并根据年龄进行排序降序
SELECT * FROM 表 WHERE sex=0 ORDER BY age ASC;
在多个列上降序排序如果想在多个列上降序排序,必须对每个列制定DESC 关键字和ASC 关键字
默认按照列值从小到大排列(ASC)ASC从小到大排列,即升序DESC从大到小排序,即降序
多列排序时将数据按照列1进行排序,如果某些列1的值相同时,则按照列2 排序,以此类推
限制查询
指定返回的行数
SELECT name FROM 表 LIMIT 5;
LIMIT 限制查询返回5行数据
指定从第几行起,返回多少行
SELECT name FROM 表 LIMIT 5,5;
返回从第5行开始不包括第5行后面的5行,第二个数为要检索的行数,
使用ORDER BY 和LIMIT的组合
取最大值
SELECT name,age FROM 表 ORDER BY age DESC LIMIT 1;
取最小值
SELECT name,age FROM 表 ORDER BY age LIMIT 1;
LIMIT 告诉MYSQL 仅返回一行所以返回的就是最大值
聚合函数
AVG() 返回某列的平均值
COUNT() 返回某列的行数
MAX() 返回某列的最大值
MIN() 返回某列的最小值
SUM() 返回某列值之和
AVG()函数
AVG()可以返回所有列的平均值,也可以返回特定咧或行的平均值
SELECT AVG(age) as avg_age FROM 表;
可以与WHERE 一起用
SELECT AVG(age) as avg_age FROM 表 WHERE 列 条件;
COUNT()函数
COUNT()函数进行计数。可利用COUNT()确定表中行的数目或符合特定条件的行的数目。 COUNT()函数有两种使用方式。 使用COUNT()对表中行的数目进行计数, 不管表列中包含的是空值( NULL)还是非空值。
SELECT COUNT() FORM 表;
使用COUNT对特定列中具有的行进行技数,忽略NULL值.
SELECT COUNT(*) FORM 表;
MAX()函数
MAX()返回指定列中的最大值.MAX()要求指定列名
SELECT MAX(age) FROM 表;
MIN()函数
MIN()的功能正好与MAX()相反,它返回制定列的最小值
SELECT MIN(age) FROM 表;
SUM()函数
SUM()用来返回制定列的总和
SELECT SUM(age) as sum__age FORM 表;
聚集不同值
下面的例子使用AVG()函数返回同学的平均价格。 它与上面的SELECT语句相同,但使用了DISTINCT参数,因此平均值只考虑各个不同的年龄:
SELECT AVG(DISTINCT age) from customers;
组合聚集函数
上面所有聚集函数例子都只涉及单个函数。但实际上SELECT语句可根据需要包含多个聚集函数。请看下面的例子:
SELECT COUNT(*) as total, MIN(age) as min_age, MAX(age) as max_age, AVG(age) as avg_age FROM customers;
mysql的分组查询
group by 分组的含义
SELECT COUNT(*) as 别名,age FROM 表 GROUP BY age;
图片.png
SELECT count(gender),gender FROM studentinfo GROUP BY gender;
SELECT avg(age),gender FROM studentinfo GROUP BY gender;
group by + group_concat()
group_concat(字段名)可以作为一个输出字段来使用,
表示分组之后,根据分组结果,使用group_concat()来放置每一组的某字段的值的集合
SELECT gender,group_concat(student_name) FROM studentinfo GROUP BY gender;
图片.png
group by + group_concat() + 集合函数
DeepinScrot-3801SELECT avg(age),gender,group_concat(student_name) FROM studentinfo GROUP BY gender;
group by + with rollup
with rollup的作用是:在最后新增一行,来记录当前列里所有记录的总和
SELECT gender,count(*) FROM studentinfo GROUP BY gender with rollup;