SQL Server 自定义字符串分割函数
作者:网络转载 发布时间:[ 2015/5/29 14:03:16 ] 推荐标签:数据库
一、按指定符号分割字符串,返回分割后的元素个数,方法很简单,是看字符串中存在多少个分隔符号,然后再加一,是要求的结果(标量值函数)
1 create function Func_StrArrayLength
2 (
3 @str varchar(1024), --要分割的字符串
4 @split varchar(10) --分隔符号
5 )
6 returns int
7 as
8 begin
9 declare @location int
10 declare @start int
11 declare @length int
12
13 set @str=ltrim(rtrim(@str))
14 set @location=charindex(@split,@str)
15 set @length=1
16 while @location<>0
17 begin
18 set @start=@location+1
19 set @location=charindex(@split,@str,@start)
20 set @length=@length+1
21 end
22 return @length
23 end
24 go
调用示例:select dbo.Func_StrArrayLength('78,1,2,3',',')
返回值:4
二、按指定符号分割字符串,返回分割后指定索引的第几个元素,象数组一样方便(标量值函数)
1 create function Func_StrArrayStrOfIndex
2 (
3 @str varchar(1024), --要分割的字符串
4 @split varchar(10), --分隔符号
5 @index int --取第几个元素
6 )
7 returns varchar(1024)
8 as
9 begin
10 declare @location int
11 declare @start int
12 declare @next int
13 declare @seed int
14
15 set @str=ltrim(rtrim(@str))
16 set @start=1
17 set @next=1
18 set @seed=len(@split)
19
20 set @location=charindex(@split,@str)
21 while @location<>0 and @index>@next
22 begin
23 set @start=@location+@seed
24 set @location=charindex(@split,@str,@start)
25 set @next=@next+1
26 end
27 if @location =0 select @location =len(@str)+1
28 --这儿存在两种情况:、字符串不存在分隔符号2、字符串中存在分隔符号,跳出while循环后,@location为,那默认为字符串后边有一个分隔符号。
29
30 return substring(@str,@start,@location-@start)
31 end
32 go
调用示例:select dbo.Func_StrArrayStrOfIndex('8,9,4',',',2)
返回值:9

sales@spasvo.com