TSQL 函數:選擇分支

来源:http://www.cnblogs.com/ljhdo/archive/2016/10/22/4821708.html
-Advertisement-
Play Games

邏輯選擇函數,判斷一個條件,根據結果的不同,返回不同的值,這類函數,可以看作是case語句的shorthand。 1,IIF 函數 該函數判斷一個邏輯表達式,如果結果為True,返回一個表達式;如果為False,返回另外一個表達式。 例如:判斷兩個變數的值,返回不同的結果 2,CHOOSE 函數 根 ...


邏輯選擇函數,判斷一個條件,根據結果的不同,返回不同的值,這類函數,可以看作是case語句的shorthand。

1,IIF 函數

該函數判斷一個邏輯表達式,如果結果為True,返回一個表達式;如果為False,返回另外一個表達式。

IIF ( boolean_expression, true_value, false_value )

例如:判斷兩個變數的值,返回不同的結果

DECLARE @a int = 45, @b int = 40;
SELECT IIF ( @a > @b, 'TRUE', 'FALSE' ) AS Result;

2,CHOOSE 函數

根據Index值,返回列表中特定位置的值;Index值可以是動態的;

CHOOSE acts like an index into an array, where the array is composed of the arguments that follow the index argument. The index argument determines which of the following values will be returned.

CHOOSE ( index, val_1, val_2 [, val_n ] )

例如:根據索引3,從列表中返回第三個value:Developer

DECLARE @idx INT
set @idx=3
SELECT CHOOSE ( @idx, 'Manager', 'Director', 'Developer', 'Tester' ) AS Result;

3,ISNULL 函數

判斷表達式是否為NULL,如果為NULL,用另一個值來代替

ISNULL ( check_expression , replacement_value )

4,COALESCE 函數

返回列表中,第一個不是NULL的表達式的值

COALESCE ( expression [ ,...n ] ) 

註意,參數列表中必須有一個表達式不是NULL,否則報錯:

At least one of the arguments to COALESCE must be an expression that is not the NULL constant.

5,CASE 語句

case語句能夠用於所有的表達式中,共有兩種寫法,如下:

case expression
    when value_1 then return_value_1
    when value_2 then return_value_2
    when value_n then return_value_n
    [else return_value_else]
end

case 
    when expression=value_1 then return_value_1
    when expression=value_2 then return_value_2
    when expression=value_n then return_value_n
    [else return_value_else]
end

在使用case語句時,有兩點需要註意:

  • when 子句的執行是有順序的:從上向下順序執行,只要條件匹配,case 語句就不再向下執行,直接返回相應的結果,即使後續的條件也滿足;
  • else 語句是可選的:如果存在else語句,表示當其他條件都不滿足時,返回return_value_else;如果省略else語句,TSQL 預設使用 else null,即,當其他條件都不滿足,返回NULL

例如,數值11 滿足第二個,第三個when子句的條件,由於when子句的執行是有順序的,但滿足第二個條件時,case 語句結束判斷,返回 middle

declare @VarInt int 
set @VarInt=11
select case when @VarInt>11 then 'high'
            when @VarInt>5 then 'middle'
            when @VarInt>1 then 'low'
            else 'omit'
        end

 

參考文檔:

CASE (Transact-SQL)

CHOOSE (Transact-SQL)

IIF (Transact-SQL)

ISNULL (Transact-SQL)

COALESCE (Transact-SQL)


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

-Advertisement-
Play Games
更多相關文章
  • 一、下載及安裝MongoDB MongoDB下載官網鏈接:http://www.mongodb.org/downloads 具體安裝步驟教程:http://www.shouce.ren/api/view/a/6191(PS:該鏈接中對MongoDB安裝講解比較詳細,通俗易懂。安裝教程鏈接是我從手冊網 ...
  • 如何把mysql的列修改成行顯示數據簡單實現 創建測試表: 1: DROP TABLE IF EXISTS `test`;<!--CRLF--> 2: CREATE TABLE `test` (<!--CRLF--> 3: `year` int(11) DEFAULT NULL,<!--CRLF-- ...
  • 出處:kelvin19840813 的博客 http://www.cnblogs.com/kelvin19840813/ 您的支持是對博主最大的鼓勵,感謝您的認真閱讀。本文版權歸作者所有,歡迎轉載,但請保留該聲明。 引用wiki: https://zh.wikipedia.org/wiki/%E6% ...
  • 在安裝mysql的過程中,出現的最麻煩的問題和解決方法 安裝後,啟動不成功,就卡了,程式就沒有響應。 如何解決: 找到mysql安裝目錄下的 #Path to the database root datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/... ...
  • 一、添加數據。 -- 1.創建表,並插入一定的數據。 -- 2.插入部分數據 二、修改數據 --1.根據條件修改數據 --2.修改多個欄位的內容 三、刪除數據(暫無演示) -- 7.刪除所有數據 -- 可以帶條件刪除,只能刪除表的數據,不能刪除表的約束,即自增長數值接著上次刪除的數值增長,刪除數據可 ...
  • 使用xcode去開發makefile的project(Building Makefile Projects With Xcode)新建工程,template選擇 external Build System添加所有的源碼到工程中。新建一個target,template選擇 external Buil... ...
  • 【函數】Oracle函數系列(1)--字元函數 1 BLOG文檔結構圖 2 前言部分 2.1 導讀和註意事項 各位技術愛好者,看完本文後,你可以掌握如下的技能,也可以學到一些其它你所不知道的知識,~O(∩_∩)O~: ① 常見字元函數(lower、upper、initcap、concat、subst ...
  • 功能概述 DDL,資料庫定義語言,創建,修改,刪除資料庫,表,視圖,索引,約束條件等 DML,資料庫操縱語言,對資料庫中的數據進行增,刪,改,查 DCL,資料庫定義語言,對資料庫總數據的訪問設置許可權 SQL語言是集DDL,DML,DCL為一體的資料庫語言,學好資料庫首先要掌握下麵9個引導詞 DDL語... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...