程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程綜合問答 >> oracle-新手請教一個sql查詢問題,在線等,謝謝

oracle-新手請教一個sql查詢問題,在線等,謝謝

編輯:編程綜合問答
新手請教一個sql查詢問題,在線等,謝謝

一張激活表TL_CSU_ACTIVATE_LOG:
圖片說明
一張用戶表TV_CSU_USER
圖片說明
現在要查詢2014-12to2015-12每月注冊的不同類型(T,B,M,D)用戶數,如下圖:
圖片說明
sql 應該怎麼寫

最佳回答:


參考Oracle行列轉換
因為你的類型是固定的,所以直接查詢,如果你的類型不固定,可以參考上面的鏈接。

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
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved