国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

oracle SQL豎表轉橫表

2024-08-29 13:57:40
字體:
來源:轉載
供稿:網友
oracle SQL 實現豎表轉橫表

T_T_STUDENT表查詢記錄如下,要轉成橫表

      姓名     課程     成績
1     張飛     語文     80
2     張飛     數學     87
3     關羽     語文     97
4     張飛     英語     68
5     關羽     數學     53
6     劉備     語文     90

方法一:
--用decode實現,
SELECT T.NAME,
       SUM(DECODE(T.Course, '語文', T.Score)) 語文,
       SUM(DECODE(T.Course, '數學', T.Score)) 數學,
       SUM(DECODE(T.Course, '英語', T.Score)) 英語
  FROM T_T_STUDENT T
GROUP BY T.NAME

方法二:
--用case  when 實現
SELECT T.NAME,
       SUM(CASE T.Course WHEN '語文' THEN T.Score ELSE 0 END) 語文,
       SUM(CASE T.Course WHEN '數學' THEN T.Score ELSE 0 END) 數學,
       SUM(CASE T.Course WHEN '英語' THEN T.Score ELSE 0 END) 英語
  FROM T_T_STUDENT T
GROUP BY T.NAME
      姓名     語文  數學  英語
1     劉備     90     94     92
2     關羽     97     53     95
3     張飛     80     87     68

區別如果條件是單一值時,用decode比較簡便,如果判斷條件比較復雜是用case when實現
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沙坪坝区| 昭平县| 六安市| 柯坪县| 慈溪市| 卢湾区| 安国市| 合江县| 宜州市| 城步| 漳州市| 前郭尔| 合阳县| 垫江县| 洛川县| 嘉禾县| 安阳县| 陈巴尔虎旗| 德阳市| 寿阳县| 宕昌县| 眉山市| 原平市| 平南县| 乌拉特后旗| 宾阳县| 高雄市| 甘谷县| 清河县| 本溪市| 蒙阴县| 巴南区| 龙州县| 沂南县| 巴林右旗| 永吉县| 德阳市| 泸定县| 呈贡县| 新巴尔虎右旗| 重庆市|