SQL里面用自定義Split()完成個(gè)性化需求
更新時(shí)間:2013年02月21日 15:06:14 作者:
為了滿(mǎn)足需求自定義Split()在SQL中實(shí)現(xiàn),代碼很整潔,感興趣的朋友可以參考下,或許對(duì)你學(xué)習(xí)sql語(yǔ)句有所幫助
復(fù)制代碼 代碼如下:
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE function [dbo].[SplitString]
(
@Input nvarchar(max),
@Separator nvarchar(max)=',',
@RemoveEmptyEntries bit=1
)
returns @TABLE table
(
[Id] int identity(1,1),
[Value] nvarchar(max)
)
as
begin
declare @Index int, @Entry nvarchar(max)
set @Index = charindex(@Separator,@Input)
while (@Index>0)
begin
set @Entry=ltrim(rtrim(substring(@Input, 1, @Index-1)))
if (@RemoveEmptyEntries=0) or (@RemoveEmptyEntries=1 and @Entry<>'')
begin
insert into @TABLE([Value]) Values(@Entry)
end
set @Input = substring(@Input, @Index+datalength(@Separator)/2, len(@Input))
set @Index = charindex(@Separator, @Input)
end
set @Entry=ltrim(rtrim(@Input))
if (@RemoveEmptyEntries=0) or (@RemoveEmptyEntries=1 and @Entry<>'')
begin
insert into @TABLE([Value]) Values(@Entry)
end
return
end
函數(shù)、表都建好了,下面調(diào)用測(cè)試一下吧:
復(fù)制代碼 代碼如下:
declare @str1 varchar(max), @str2 varchar(max), @str3 varchar(max)
set @str1 = '1,2,3'
set @str2 = '1###2###3'
set @str3 = '1###2###3###'
select [Value] from [dbo].[SplitString](@str1, ',', 1)
select [Value] from [dbo].[SplitString](@str2, '###', 1)
select [Value] from [dbo].[SplitString](@str3, '###', 0)
結(jié)果,截個(gè)圖來(lái)看一下:
相關(guān)文章
分頁(yè) SQLServer存儲(chǔ)過(guò)程
分頁(yè) SQLServer存儲(chǔ)過(guò)程...2006-08-08
SQL Server 2012 FileTable 新特性詳解
FileTable是基于FILESTREAM的一個(gè)特性。本文給大家介紹SQL Server 2012 FileTable 新特性詳解,非常不錯(cuò),感興趣的朋友一起學(xué)習(xí)吧2016-08-08
分區(qū)表場(chǎng)景下的 SQL 優(yōu)化
這篇文章主要介紹了分區(qū)表場(chǎng)景下的 SQL 優(yōu)化,幫助大家更好的理解和學(xué)習(xí)SQL,感興趣的朋友可以了解下2020-08-08
SQL命令優(yōu)化需要記住的9點(diǎn)事項(xiàng)
SQL命令優(yōu)化這是個(gè)自從數(shù)據(jù)庫(kù)誕生的時(shí)候就開(kāi)始討論的話(huà)題,每個(gè)人都有自己的理解,當(dāng)然,本人也有些經(jīng)驗(yàn),總結(jié)給大家,希望對(duì)大家有所幫助2014-08-08
淺述SQL Server的語(yǔ)句類(lèi)別 數(shù)據(jù)庫(kù)范式 系統(tǒng)數(shù)據(jù)庫(kù)組成
本文著重講解了SQL語(yǔ)句的組成以及數(shù)據(jù)庫(kù)的三個(gè)范式,對(duì)系統(tǒng)數(shù)據(jù)庫(kù)的組成進(jìn)行簡(jiǎn)短的介紹。有興趣的朋友可以看下2016-12-12
基于SQL Server OS的任務(wù)調(diào)度機(jī)制詳解
本篇文章小編為大家介紹,基于SQL Server OS的任務(wù)調(diào)度機(jī)制詳解。需要的朋友參考下2013-04-04
Replace關(guān)鍵字的妙用查詢(xún)是否包含某個(gè)特定字符串
Replace關(guān)鍵字主要是用來(lái)將字符串中的某個(gè)字符替換成別的字符,今天要為大家介紹下使用它來(lái)查詢(xún)是否包含某個(gè)特定字符串,示例代碼如下,感興趣的朋友可以參考下2013-08-08

