数据库case,when学习
前几天工作中遇到了一个数据库统计相关的东西,主要使用case,when实现。如今说说基本情况:
有两个表school,studens,当中
school表结构例如以下:
students表结构例如以下:
当中sex=1代表男,sex=2代表女
现要求出现例如以下的结果集:
学校id,学校名,学校总人数。男生总人数。女生总人数
方案:
1。将school表和students表分别查询统计出学校总人数,男生总人数,女生总人数,然后将结果集拼起来即可了。此方法比較传统,想法简单,可是sql过长。
2.採用case,when语句,在count聚合函数使用,详细代码例如以下:
SELECT c.id ,
c.NAME ,
( c.boyCount + c.girlCount ) AS TotalCount ,
c.boyCount ,
c.girlCount
FROM ( SELECT b.id ,
b.name ,
COUNT(CASE WHEN a.sex = 1 THEN 1
ELSE NULL
END) AS boyCount ,
COUNT(CASE WHEN a.sex = 2 THEN 1
ELSE NULL
END) AS girlCount
FROM [guagua_new_event_system_test].[dbo].[students] a ,
[guagua_new_event_system_test].[dbo].[school] b
WHERE a.school_id = b.id
GROUP BY b.id ,
b.name
) AS c
算是数据库的一种学习吧!
路漫漫其修远兮。吾将上下而求索!