mysql聚合函数

group_concat  可以对分组查询后的值进行拼接,如

select a group_concat(b) from z group by a;  就会按a列分组,b列对应聚合结果以逗号进行分隔

 

select 与 case结合使用最大的好处有两点,一是在显示查询结果时可以灵活的组织格式,二是有效避免了多次对同一个表或几个表的访问。  可以完成行转列的操作

下面举个简单的例子来说明。例如表 students(id, name ,birthday, sex, grade),要求按每个年级统计男生和女生的数量各是多少,统计结果的表头为,年级,男生数量,女生数量。如果不用select case when,为了将男女数量并列显示,统计起来非常麻烦,先确定年级信息,再根据年级取男生数和女生数,而且很容易出错。

用select case when写法如下:
SELECT grade, COUNT (CASE WHEN sex = 1 THEN 1     
                            ELSE NULL
                        END) 男生数,
               COUNT (CASE WHEN sex = 2 THEN 1
                            ELSE NULL
                       END) 女生数
FROM students

GROUP BY grade;

 

行转列举例:

如对日志的保存字段为:

id   attribute value      

1    attr1    BMW

1    attr2    100

1    attr3     2013-01-01

需要针对不同的attribute按照id进行分组统计,可以

select id,

        Max(case when attribute='attr1' then value  end)   as attr1

        Max(case when attribute='attr2' then value end) as attr2

        Max(case when attribute='attr3' then value end) as attr3

        Max(case when attribute='attr4' then value end) as attr4

from t

group by id;

Max用来对case中符合条件的取出最大值,也可以用count()来统计个数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值