SQL SERVER 2012新增函數(shù)之邏輯函數(shù)CHOOSE詳解
SQL SERVER 2012中新增了CHOOSE,該函數(shù)可以從值列表返回指定索引處的項。
例如:
select CHOOSE(3,'A','B','C','D') as R1 /* R1 ---- C */
CHOOSE并不能這么用,例如有個字符串'A,B,C,D',我們并不能用choose得到其中的某個值:
select choose(2,'A,B,C,D') /* null */
CHOOSE的主要功能和CASE WHEN類似,例如數(shù)據(jù)庫中有字段Sex:1表示男,2表示女。
if object_id('[tb]') is not null drop table [tb] create table [tb]([Id] int,[Name] varchar(4),[Sex] int) insert [tb] select 1,'張三',1 union all select 2,'李四',2 union all select 3,'王五',1 select * from [tb] /* Id Name Sex --------------- ----------- 1 張三 1 2 李四 2 3 王五 1 */
以前用CASE WHEN
select Id,Name,case Sex when 1 then '男' when2 then '女' else '' end as sex from [tb]
有了CHOOSE以后,可以這樣:
select Id,Name,CHOOSE(Sex,'男','女') as sex from [tb] /* Id Name sex --------------- ---- 1 張三 男 2 李四 女 3 王五 男 */
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
修改SQL-SERVER數(shù)據(jù)庫表結(jié)構(gòu)的SQL命令附sql命令行修改數(shù)據(jù)庫
本教程給大家介紹修改SQL-SERVER數(shù)據(jù)庫表結(jié)構(gòu)的SQL命令附sql命令行修改數(shù)據(jù)庫,涉及到sqlserver數(shù)據(jù)庫命令的相關知識,對sqlserver數(shù)據(jù)庫命令感興趣的朋友可以參考下本篇文章2015-10-10sql中的left join及on、where條件關鍵字的區(qū)別詳解
LEFT JOIN 關鍵字從左表(table1)返回所有的行,即使右表(table2)中沒有匹配。如果右表中沒有匹配,則結(jié)果為 NULL。這篇文章主要介紹了sql中的left join以及on、where關鍵字的區(qū)別,需要的朋友可以參考下2018-08-08uniqueidentifier轉(zhuǎn)換成varchar數(shù)據(jù)類型的sql語句
uniqueidentifier轉(zhuǎn)換成varchar數(shù)據(jù)類型的sql語句,需要的朋友可以參考下。2011-09-09SQLServer 2000 升級到 SQLServer 2008 性能之需要注意的地方之一
今天在 相同環(huán)境測試 2000 和 2008 性能 讓我意外的是 2008 明顯比2000 慢很多,因為不能簡單的升級,sql語句也需要優(yōu)化2012-02-02SQLServer獲取臨時表所有列名或是否存在指定列名的方法
本文介紹了SQLServer獲取臨時表所有列名或是否存在指定列名的方法,需要的朋友一起來看下吧2016-12-12