表的轉置 行轉列: DECODE(Oracle) 和 CASE WHEN 的異同點

来源:https://www.cnblogs.com/Joyce-marmot/archive/2018/11/08/9931584.html
-Advertisement-
Play Games

一. DECODE方法 (Oracle公司獨家) decode(條件,值1,返回值1,值2,返回值2,...值n,返回值n,預設值) 二. CASE WHEN Case函數只返回第一個符合條件的值,剩下的Case部分將會被自動忽略 Case具有兩種格式,簡單Case函數的寫法相對比較簡潔,但是和Ca ...


異同點
  • 都可以對錶行轉列;
  • DECODE功能上和簡單Case函數比較類似,不能像Case搜索函數一樣,進行更複雜的判斷
  • 在Case函數中,可以使用BETWEEN, LIKE, IS NULL, IN, EXISTS等等(也可以使用NOT IN和NOT EXISTS,但是這個時候要註意NULL的情況。)
DECODE方法 (Oracle公司獨家)

decode(條件,值1,返回值1,值2,返回值2,...值n,返回值n,預設值)

--該函數的含義如下:    
IF    條件=值1 THEN RETURN(翻譯值1)   
ELSIF 條件=值2 THEN RETURN(翻譯值2)  
    ......  
ELSIF 條件=值n THEN RETURN(翻譯值n)  
ELSE  RETURN(預設值)  
END IF   
--行轉列
SELECT name,  
       SUM(DECODE(Subject, '數學', Score, 0)) 數學,  
       SUM(DECODE(Subject, '語文', Score, 0)) 語文,  
       SUM(DECODE(Subject, '英語', Score, 0)) 英語  
FROM Scores 
GROUP BY name  
CASE WHEN
SELECT name,
SUM( CASE WHEN Subject='數學' THEN Score ELSE 0 END) 數學,
SUM( CASE WHEN Subject='語文' THEN Score ELSE 0 END) 語文,
SUM( CASE WHEN Subject='英語' THEN Score ELSE 0 END) 英語
FROM Scores group by name;

Case函數只返回第一個符合條件的值,剩下的Case部分將會被自動忽略,Else部分的預設值是NULL

Case具有兩種格式,簡單Case函數的寫法相對比較簡潔,但是和Case搜索函數相比,功能方面會有些限制,比如寫判斷式

在Case函數中,可以使用BETWEEN, LIKE, IS NULL, IN, EXISTS等等(也可以使用NOT IN和NOT EXISTS,但是這個時候要註意NULL的情況。)

--簡單Case函數
CASE sex
WHEN '1' THEN '男'
WHEN '2' THEN '女'
ELSE '其他' END

--Case搜索函數 
CASE 
WHEN sex = '1' THEN '男' 
WHEN sex = '2' THEN '女' 
ELSE '其他' END  

--根據條件有選擇的UPDATE。
UPDATE Scores  SET grade = 
CASE WHEN score >= 85 THEN '優秀'
     WHEN score >= 70 AND score < 85  THEN '良好' 
     WHEN score >= 60 AND score < 70  THEN '及格'
ELSE '不及格' END; 

--在Case函數中使用聚合函數:COUNT, SUM, AVG, MAX, MIN
SELECT  name, 
CASE WHEN COUNT(*) = 1 THEN MAX(subject) 
ELSE MAX(CASE WHEN major = 'Y'  THEN subject ELSE NULL END) 
END AS major_subject
FROM Scores  GROUP BY name; 
Scores表結構和實現如下

image
image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、命令介紹 touch 命令用於創建空白文件,以及設置文件的時間。 二、實例 我們使用touch 命令創建一個空白文件,名為test.txt touch test.txt 可以看到,使用touch命令創建空白文件的命令 相當簡潔。 假設,我們要繼續創建空白文件test1.txt、test2.txt ...
  • 之前,我寫了使用cmd查看電腦連接過的wifi密碼(二)和使用cmd查看電腦連接過的wifi密碼(一)但其中的功能不完善,在本次的更新中新增了更多的功能,其實2018/10/24 就更新完成了,一直拖到現在主要是為了驗證程式在不同機子上的執行情況併進行修正。 註意本軟體只用於學習和正當途徑,如果有人 ...
  • 本操作系統郵件由來,crontab定時任務執行推送產生。 1.查看有多少封郵件 2.我們直接鍵入23935來訪問這封mail,看看是否是我們所需要的最新郵件。 3. 退出郵件查看 ctrl+z ...
  • 一、yum命令概述: 1、簡介: yum命令時在Fedora和RedHat以及SUSE中基於rpm的軟體包管理器,它可以使系統管理人員交互和自動化地更細與管理RPM軟體包,能夠從指定的伺服器自動下載RPM包並且安裝,可以自動處理依賴性關係,並且一次安裝所有依賴的軟體包,無需繁瑣地一次次下載、安裝。 ...
  • tail 命令從指定點開始將文件寫到標準輸出.使用tail命令的 f選項可以方便的查閱正在改變的日誌文件,tail f filename會把filename里最尾部的內容顯示在屏幕上,並且不斷刷新,使你看到最新的文件內容. 一.命令格式; tail [必要參數] [選擇參數] [文件] 二.命令功能 ...
  • 有以下存儲過程: 有這個表: 調用存儲過程: 結果: ...
  • redis事務 1.redis事務介紹 redis的事務可以理解為一系列串列命令的集合。redis的事務和單條命令一樣,都是redis的最小執行單位,因此一個事務內的命令,要麼全部執行,要麼全部不執行。事務的概念對於熟悉資料庫的人們並不陌生,而redis作為一個資料庫系統,必然會對事務進行一定的支持 ...
  • 當需要從資料庫查詢的表有上萬條記錄的時候,一次性查詢所有結果會變得很慢,特別是隨著數據量的增加特別明顯,這時需要使用分頁查詢。對於資料庫分頁查詢,也有很多種方法和優化的點。下麵簡單說一下我知道的一些方法。 準備工作 為了對下麵列舉的一些優化進行測試,下麵針對已有的一張表進行說明。 表名:order_ ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...