码迷,mamicode.com
首页 > 其他好文 > 详细

关于CASE WHEN的多条件汇总问题

时间:2018-06-01 13:24:33      阅读:284      评论:0      收藏:0      [点我收藏+]

标签:group by   target   cts   sele   prim   数据   obj   get   exists   

https://bbs.csdn.net/topics/392217817?page=1

问题:

--创建测试表
IF  EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N[dbo].[TB]) AND type in (NU))
DROP TABLE [dbo].[TB1]
GO
CREATE TABLE [dbo].[TB1](
    [卡状态] [nvarchar] (20) NULL,
    [卡类型] [nvarchar](50) NULL,
) ON [PRIMARY]
GO
 
--插入测试数据
INSERT INTO [TB1] ([卡状态],[卡类型]) 
    SELECT N发卡,N正式卡 UNION ALL
    SELECT N发卡,N正式卡 UNION ALL
    SELECT N发卡,N临式卡 UNION ALL
    SELECT N制卡,N临式卡 UNION ALL
    SELECT N制卡,N正式卡
GO
 
SELECT * FROM TB1

 

技术分享图片

 回帖:

SELECT  卡状态 +  ,
        COUNT(1) AS 总数 ,
        SUM(CASE WHEN 卡类型 = 正式卡 THEN 1
                 ELSE 0
            END) AS 正式卡 ,
        SUM(CASE WHEN 卡类型 = 临式卡 THEN 1
                 ELSE 0
            END) AS 临式卡
FROM    TB1
GROUP BY 卡状态

 

技术分享图片

 

关于CASE WHEN的多条件汇总问题

标签:group by   target   cts   sele   prim   数据   obj   get   exists   

原文地址:https://www.cnblogs.com/yadongliang/p/9120831.html

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