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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...