mysql按照年龄区间分组查询

需求:统计不同年龄区间的男女人数,比如0-9岁之间、10-19、20-29、30-39……每个年龄段中男女人数分别是多少。

实现:使用mysql中的interval函数。

interval(a,a1,a2,a3,a4)

其中第一个参数a为要做比较的值,a2以及a2之后的参数为条件参数。当a为null的时候,返回-1。当a<a1的时候返回0,a<a2的时候返回1,a<a3的时候返回2,以此类推。需要注意的是,条件参数必须是以小到大的方式排列。

此时,就可以进行统计分组了,写法为:

select 

interval(年龄字段,10,20,30,40,50,60,70,80,90,100) as ageRange  ,

sum(case when 性别字段 = 1 then 1 else 0 end) as man,            //求男性人数   性别字段=1表示男性,当性别字段中的值为1时man+1

sum(case when 性别字段 = 0 then 1 else 0 end) as madam           //求女性人数

from 表名

where 条件

group by ageRange                                               //根据年龄段进行分组

  实例:

                SELECT

                INTERVAL(patientAge,10,20,30,40,50,60,70,80,90)
                AS
                         ageRange,

                        SUM(CASE WHEN patientSex=1 THEN 1 ELSE 0 END)
                AS
                        appointmentNumM,
                        SUM(CASE WHEN patientSex=0 THEN 1 ELSE 0 END)
                AS
                        appointmentNumF
                FROM
                        t_appointment
                WHERE
                        1=1
                GROUP BY ageRange
                LIMIT
                        1,10

结果为:

此时,年龄区间为0-9岁(ageRange为0的统计结果)的男性有406人,女性为380人;10-19之间(ageRange为1的统计结果)的男性213人,女性99人,20-29之间(ageRange为2的统计结果)的男性269人,女性241人等等。。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值