資料庫:case when then

来源:http://www.cnblogs.com/goldpumpkin/archive/2017/05/30/6921312.html
-Advertisement-
Play Games

CASE WHEN 條件 THEN 改變的值 END 1.簡單case函數,使用表達式確定返回值: 語法: CASE title WHEN expression1 THEN result1 WHEN expression2 THEN result2 ... WHEN expressionN THEN ...


CASE WHEN 條件 THEN 改變的值 END

1.簡單case函數,使用表達式確定返回值:

語法:

CASE title 
    WHEN expression1 THEN result1
    WHEN expression2 THEN result2
    ...
    WHEN expressionN THEN resultN
ELSE default_res

2.搜索case表達式,使用條件確定返回值(一般使用)

語法:

CASE
    WHEN condition1 THEN result1
    WHEN condition2 THEN result2
    ...
    WHEN conditionN THEN resultN
ELSE default_result
END



eg:

SELECT sex
    CASE 
    WHEN sex=0 then '男'
    WHEN sex=1 then '女'
    ELSE '未知'
    END
FROM student;

3.一些例子

1>已知數據按照另外一種方式進行分組,分析。

    根據這個國家人口數據,統計亞洲和北美洲的人口數量

country population
中國 600
美國 100
加拿大 100
英國 200
法國 300
日本 250

SELECT SUM(population),
    CASE country
        WHEN '中國' THEN '亞洲'
        WHEN '日本' THEN '亞洲'
        WHEN '美國' THEN '北美洲'
        WHEN '加拿大' THEN '北美洲'
        ELSE '其他'
    END
FROM table_A
    GROUP BY 
        CASE country
            WHEN '中國' THEN '亞洲'
            WHEN '日本' THEN '亞洲'
            WHEN '美國' THEN '北美洲'
            WHEN '加拿大' THEN '北美洲'
            ELSE '其他'
        END;    

2>求各個分數段的人數

SELECT 
    SUM(CASE WHEN score = 81 THEN 1 end) 81,
    SUM(CASE WHEN score = 82 THEN 1 end) 82,
    SUM(CASE WHEN score = 83 THEN 1 end) 83
 FROM SCORE;

註意:如果使用count(),也行。count()統計數據總數,sum()求和某欄位下麵的所有數據

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

-Advertisement-
Play Games
更多相關文章
  • Asp.Net Core MVC RazorPage多語言實現方法 ...
  • 可以編寫angularjs的自定義指令來實現驗證文本框填入的數值是來為小數。 airExpressApp.directive('validateDecimalCharacters', function () { var REQUIRED_PATTERNS = [ /^-?[0-9]\d*(\.\d+ ...
  • 前幾天Insus.NET有寫過一篇《angularjs自定義指令Directive》http://www.cnblogs.com/insus/p/6908815.html 僅是在程式中指定某些來值來匹配。為你的數據表準備一個存儲過程: 判斷是否已經存在此值。只需寫SELECT語句。如果沒有記錄返回, ...
  • // 使用原生js 封裝ajax // 相容xhr對象 function createXHR(){ if(typeof XMLHttpRequest != "undefined"){ // 非IE6瀏覽器 return new XMLHttpRequest(); }else if(typeof Ac... ...
  • SpringMVC中,如何處理請求是很重要的任務。請求映射都會使用@RequestMapping標註。其中,類上的標註相當於一個首碼,表示該處理器是處理同一類請求;方法上的標註則更加細化。如,類的標註可能是“user”,表示全部都是與用戶相關的操作;具體到方法可能有“create”“update”“ ...
  • 寫代碼的不要耍小聰明,認認真真的敲。 代碼是給人看的,只是順便給機器去執行。 ...
  • 歡迎大家每天前來打卡~ 訓練營規則 每天出一道練習題,請大家自己完成編碼 第二天的文章中會告訴大家一種或幾種經典解決方法 完成練習的同學,歡迎大家把代碼貼在留言中 如果有問題,也請留言,我會找機會集中解答 希望這種手把手的方式能夠幫助大家儘快掌握C語言編程。 1. 例題 今天我們先來講解一道C語言的 ...
  • 要處理XML文檔,就要先解析(parse)他,解析器時這樣一個程式,讀入一個文件,確認整個文件具有正確的格式,然後將其分解成各種元素,使得程式員能夠訪問這些元素,Java庫提供了兩種XML解析器: 像文檔對象模型(Document Object Model,DOM)解析器這樣的樹型解析器,他們將讀入... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...