SQL Server 自定义字符串分割函数

发表于:2015-5-29 11:48

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:KenmuHuang    来源:51Testing软件测试网采编

  一、按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果(标量值函数)
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
21/212>
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号