开发者社区> 问答> 正文

请教一个sql查询问题

一张激活表TL_CSU_ACTIVATE_LOG:
screenshot
一张用户表TV_CSU_USER
screenshot
现在要查询2014-12to2015-12每月注册的不同类型(T,B,M,D)用户数,如下图:
screenshot
sql 应该怎么写

展开
收起
吴孟桥 2016-06-15 18:21:57 1994 0
1 条回答
写回答
取消 提交回答
  • 因为你的类型是固定的,所以直接查询,如果你的类型不固定,可以参考上面的链接。

    SELECT TT.Month

    ,SUM(CASE WHEN TT.TYPE = 'B' THEN Count ELSE 0 END) AS B
    ,SUM(CASE WHEN TT.TYPE = 'M' THEN Count ELSE 0 END) AS M
    ,SUM(CASE WHEN TT.TYPE = 'D' THEN Count ELSE 0 END) AS D
    ,SUM(CASE WHEN TT.TYPE = 'T' THEN Count ELSE 0 END) AS T

    FROM (
    SELECT TO_CHAR(T1.ACTIVATE_TIME, 'yyyy-MM') AS Month

        , T2.TYPE
        , COUNT(*) AS Count
      FROM TL_CSU_ACTIVATE_LOG T1
      LEFT JOIN TV_CSU_USER T2 ON T2.USER_ID = T1.USER_ID
      WHERE TO_CHAR(T1.ACTIVATE_TIME, 'yyyy-MM') >= '2014-12' AND TO_CHAR(T1.ACTIVATE_TIME, 'yyyy-MM') <= '2015-12'

    GROUP BY T2.TYPE
    ) TT
    GROUP BY TT.Month
    ORDER BY TT.Month

    2019-07-17 19:39:59
    赞同 展开评论 打赏
问答分类:
SQL
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
SQL Server 2017 立即下载
GeoMesa on Spark SQL 立即下载
原生SQL on Hadoop引擎- Apache HAWQ 2.x最新技术解密malili 立即下载