SQL 自定义Split函数

在给文章加自定义标签时,需要在存储过程中对输入的字符串按照“,”字符分割成一个字符数组。但是Sql中没有实现字符串分组的Split方 法。因此就需要编写一个自定义的Split函数。我首先是使用表值函数的方法实现的字符串分组,但是在使用中感觉不是很方便。后来又在网上找到了一种使用 两个标量函数,其中一个函数首先返回分割后字符数组的长度,另一个函数依次返回每个分割出的字符串。然后使用循环依次获取分割的字符。


表值函数实现Split方法


 1 Create FUNCTION [dbo].[SplitToTable]
 2 (
 3     @SplitString nvarchar(max),
 4     @Separator nvarchar(10)=' '
 5 )
 6 RETURNS @SplitStringsTable TABLE
 7 (
 8 [id] int identity(1,1),
 9 [value] nvarchar(max)
10 )
11 AS
12 BEGIN
13     DECLARE @CurrentIndex int;
14     DECLARE @NextIndex int;
15     DECLARE @ReturnText nvarchar(max);
16     SELECT @CurrentIndex=1;
17     WHILE(@CurrentIndex<=len(@SplitString))
18         BEGIN
19             SELECT @NextIndex=charindex(@Separator,@SplitString,@CurrentIndex);
20             IF(@NextIndex=0 OR @NextIndex IS NULL)
21                 SELECT @NextIndex=len(@SplitString)+1;
22                 SELECT @ReturnText=substring(@SplitString,@CurrentIndex,@NextIndex-@CurrentIndex);
23                 INSERT INTO @SplitStringsTable([value]) VALUES(@ReturnText);
24                 SELECT @CurrentIndex=@NextIndex+1;
25             END
26     RETURN;
27 END
select * FROm dbo.SplitToTable('111,b2222,323232,32d,e,323232f,g3222', ',')


结果为


id          value
----------- ---------------------------------------
1           111
2           b2222
3           323232
4           32d
5           e
6           323232f
7           g3222


(7 行受影响)


使用循环的方法


首先GetSplitLength函数返回分割后的字符数组的长度。


 1 Create function [dbo].[GetSplitLength]
 2 (
 3  @String nvarchar(max),  --要分割的字符串
 4  @Split nvarchar(10)  --分隔符号
 5 )
 6 returns int
 7 as
 8 begin
 9  declare @location int
10  declare @start int
11  declare @length int
12 
13  set @String=ltrim(rtrim(@String))
14  set @location=charindex(@split,@String)
15  set @length=1
16  while @location<>0
17  begin
18    set @start=@location+1
19    set @location=charindex(@split,@String,@start)
20    set @length=@length+1
21  end
22  return @length
23 end
select dbo.GetSplitLength('111,b2222,323232,32d,e,323232f,g3222',',')


结果为7。


GetSplitOfIndex函数是按顺序分别获取分割后的字符串。


 1 ALTER function [dbo].[GetSplitOfIndex]
 2 (
 3  @String nvarchar(max),  --要分割的字符串
 4  @split nvarchar(10),  --分隔符号
 5  @index int --取第几个元素
 6 )
 7 returns nvarchar(1024)
 8 as
 9 begin
10  declare @location int
11  declare @start int
12  declare @next int
13  declare @seed int
14 
15  set @String=ltrim(rtrim(@String))
16  set @start=1
17  set @next=1
18  set @seed=len(@split)
19  
20  set @location=charindex(@split,@String)
21  while @location<>0 and @index>@next
22  begin
23    set @start=@location+@seed
24    set @location=charindex(@split,@String,@start)
25    set @next=@next+1
26  end
27  if @location =0 select @location =len(@String)+1 
29  
30  return substring(@String,@start,@location-@start)
31 end
 select dbo.GetSplitOfIndex('111,b2222,323232,32d,e,323232f,g3222',',', 3)


结果323232。


 1 DECLARE @Tags nvarchar(max);
 2 SELECT @Tags='111,b2222,323232,32d,e,323232f,g3222';
 3 DECLARE @Tag nvarchar(1000)
 4 DECLARE @next int;
 5 set @next=1
 6 
 7 DECLARE @Length int;
 8 SELECT @Length=dbo.GetSplitLength(@Tags,',')
 9 
10 while @next<=@Length
11 begin
12     SET @Tag = left(dbo.GetSplitOfIndex(@Tags,',',@next), 16);
13     print @Tag
14     SET @Next=@Next+1;
15 END
结果为:


111
b2222
323232
32d
e
323232f
g3222

你可能感兴趣的:(SQL 自定义Split函数)