mysql-查询2

分组查询 group by

group by 属性名 [having 条件表达式][ with rollup]

“属性名 ”指按照该字段值进行分组;“having 条件表达式 ”用来限制分组后的显示,满足条件的结果将被显示;with rollup 将会在所有记录的最后加上一条记录,该记录是上面所有记录的总和。

1)单独使用

group by 单独使用,查询结果只显示一个分组的一条记录。
实例:
select * from employee group by sex;
将只显示男女两条记录。

2)与group_concat()函数一起使用

每个分组中指定字段值都显示出来
实例:
select sex,group_concat(name) from employee group by sex;
显示结果中“女”会显示所有sex为“女”的名字name

sex | group_concat(name)
女 | 小红,小兰
男 | 张三,王五,王六

3)与集合函数一起使用

实例:
select sex,count(sex) from employee group by sex;
结果:

sex | count(num)
女 | 1
男 | 3

count()为计算个数的方法。

4)与having一起使用

“having条件表达式”,可以限制输出结果。只有满足条件表达式的结果才显示。
实例:
select sex,count(sex) from employee group by sex having count(sex) >= 3;
结果:

sex | count(sex)
男 | 3

“having条件表达式”作用于分组后的记录。

5)按多字段进行分组

select * from employee group by d_id,sex;
查询结果先按d_id分组,再按sex进行分组

6) 与with rollup一起使用

使用with rollup将会在所有记录的最后加上一条记录,这条记录是上面所有记录的总和
实例:
select sex,count(sex) from employee group by sex with rollup;
结果:

sex | count(sex)
女 | 1
男 | 5
null | 6

如果是字符串的话,比如姓名就会生成“张三,李四,王五”这种类型的结果,即name总和。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 查询基础 算术运算符 (+)(-)(*)(/) 值得注意的是:/ 在oracle中就相当于显示中的除法 5/2 =...
    Autism_37a1阅读 489评论 0 0
  • 目录 简介 在Android中存储数据有时会用到数据库,Android给我们提供了 一系列的API来操作数据库,非...
    慕涵盛华阅读 1,035评论 1 2
  • 查询是数据的一个重要操作。用户发送查询请求,经编译软件变异成二进制文件供服务器查询,后返回查询结果集给用户,查询会...
    产品小正阅读 1,435评论 0 2
  • mysql数据库中 :database : 文件夹table : 数据表(数据文件) 进入mysqlmysql -...
    赋闲阅读 580评论 0 0
  • 亲爱的妈妈们,大家好。我整理了团队五月份各项活动的奖励情况。大家都知道,六月份大V店会启动城市合伙人项目,也就是说...
    蜜芯儿阅读 274评论 0 0