一、按指定符号分割字符串,返回分割后的元素个数,方法很简单,是看字符串中存在多少个分隔符号,然后再加一,是要求的结果(标量值函数
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