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() + 集合函数

SELECT avg(age),gender,group_concat(student_name) FROM studentinfo GROUP BY gender;

DeepinScrot-3801

group by + with rollup

with rollup的作用是:在最后新增一行,来记录当前列里所有记录的总和

SELECT gender,count(*) FROM studentinfo GROUP BY gender with rollup;
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容