码迷,mamicode.com
首页 > 数据库 > 详细

数据库case,when学习

时间:2015-03-13 16:36:19      阅读:138      评论:0      收藏:0      [点我收藏+]

标签:数据库sql语句学习

前几天工作中遇到了一个数据库统计相关的东西,主要使用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

算是数据库的一种学习吧!
路漫漫其修远兮,吾将上下而求索!

数据库case,when学习

标签:数据库sql语句学习

原文地址:http://blog.csdn.net/figthinbeijing/article/details/44242081

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!