主頁 > 知識庫 > SQL SERVER2012中新增函數(shù)之字符串函數(shù)CONCAT詳解

SQL SERVER2012中新增函數(shù)之字符串函數(shù)CONCAT詳解

熱門標簽:AI電銷 鐵路電話系統(tǒng) 地方門戶網(wǎng)站 網(wǎng)站排名優(yōu)化 呼叫中心市場需求 百度競價排名 服務外包 Linux服務器

介紹

SQLSERVER 2012新增了兩個字符串函數(shù)CONCAT和FORMAT。本文首先介紹一下CONCAT,CONCAT函數(shù)的作用是可以返回多個字符串拼接后的結(jié)果。

CONCAT 函數(shù)最多可以連接255個字符變量,當調(diào)用這個函數(shù)的時候需要至少接收兩個參數(shù),參數(shù)類型不一定是字符串類型,也可以是可以隱式轉(zhuǎn)換為字符串的類型比如int ,float等類型。只要符合sql 2012的能隱式轉(zhuǎn)換為字符串的規(guī)則即可,當我們想把兩個值類型的數(shù)據(jù)連接起來的時候,不需要先將它們轉(zhuǎn)為nvarchar然后再通過“+”來連接了

簡單示例:

select CONCAT('a','b') as R1 
/* 
R1 
---- 
ab 
*/ 
select 'a'+'b' as R2 
/* 
R2 
---- 
ab 
*/ 

如此看來這個函數(shù)似乎使SQL語句變得更長了,這個函數(shù)到底有什么優(yōu)點呢?

下面我舉個實例說明一下(數(shù)據(jù)就從百度隨便搜了個排行榜)

if object_id('tb') is not null drop table tb 
create table tb([Rank] int,[Name] varchar(10),[SearchTime] int,[Remarks] varchar(10)) 
insert tb 
select 1,'完美世界',118251,'我沒看過' unionall 
select 2,'莽荒紀',104532,'我沒看過' unionall 
select 3,'大主宰',93453,'我沒看過' unionall 
select 4,'絕世唐門',63333,'我沒看過' unionall 
select 5,'最強棄少',38198,'我沒看過' unionall 
select 6,'傲世九重天',31137,'我沒看過' unionall 
select 7,'唐磚',29166,'我沒看過' unionall 
select 8,'武極天下',26435,'我也沒看過' unionall 
select 9,'魔天記',25227,'我都沒看過' unionall 
select 10,'劍道獨尊',25097,null 

針對以上數(shù)據(jù),例如我們要得到如下結(jié)果:

第1名:完美世界 搜索指數(shù):118251 備注:我沒看過

也許我們會這樣寫:

select '第'+ltrim([Rank])+'名:'+[Name]+' 搜索指數(shù):'+ltrim([SearchTime])+' 備注:'+isnull([Remarks],'') as R3 from tb 
/* 
R3 
-------------------------------------------------------------------- 
第1名:完美世界搜索指數(shù):118251 備注:我沒看過 
第2名:莽荒紀搜索指數(shù):104532 備注:我沒看過 
第3名:大主宰搜索指數(shù):93453 備注:我沒看過 
第4名:絕世唐門搜索指數(shù):63333 備注:我沒看過 
第5名:最強棄少搜索指數(shù):38198 備注:我沒看過 
第6名:傲世九重天搜索指數(shù):31137 備注:我沒看過 
第7名:唐磚搜索指數(shù):29166 備注:我沒看過 
第8名:武極天下搜索指數(shù):26435 備注:我也沒看過 
第9名:魔天記搜索指數(shù):25227 備注:我都沒看過 
第10名:劍道獨尊搜索指數(shù):25097 備注: 
*/ 

有了CONCAT以后,我們可以這樣:

select concat('第',[Rank],'名:',[Name],' 搜索指數(shù):',[SearchTime],' 備注:',[Remarks]) as R4 from tb 
/* 
R4 
--------------------------------------------------------------------- 
第1名:完美世界 搜索指數(shù):118251 備注:我沒看過 
第2名:莽荒紀 搜索指數(shù):104532 備注:我沒看過 
第3名:大主宰 搜索指數(shù):93453 備注:我沒看過 
第4名:絕世唐門 搜索指數(shù):63333 備注:我沒看過 
第5名:最強棄少 搜索指數(shù):38198 備注:我沒看過 
第6名:傲世九重天 搜索指數(shù):31137 備注:我沒看過 
第7名:唐磚 搜索指數(shù):29166 備注:我沒看過 
第8名:武極天下 搜索指數(shù):26435 備注:我也沒看過 
第9名:魔天記 搜索指數(shù):25227 備注:我都沒看過 
第10名:劍道獨尊 搜索指數(shù):25097 備注: 
*/ 

從上面的實例中我們可以看到CONCAT的兩個優(yōu)點:

      1.當數(shù)據(jù)類型不一致的時候可以自動轉(zhuǎn)換;

      2.對于null的處理,不用isnull也可以避免因拼接而導致結(jié)果為null的情況。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • C語言字符函數(shù)、內(nèi)存函數(shù)功能及實現(xiàn)代碼
  • C語言去除相鄰重復字符函數(shù)的實現(xiàn)方法
  • PHP常用字符串函數(shù)用法實例總結(jié)
  • php字符串函數(shù) str類常見用法示例
  • 深入了解C語言字符函數(shù)和字符串函數(shù)

標簽:崇左 蘭州 仙桃 黃山 銅川 衡水 湘潭 湖南

巨人網(wǎng)絡通訊聲明:本文標題《SQL SERVER2012中新增函數(shù)之字符串函數(shù)CONCAT詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266