需求:统计不同年龄区间的男女人数,比如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人等等。。