微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQLserver字符串分割函数

一、按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果。

CREATE function Get_StrArrayLength
(
  @str varchar(1024),  --要分割的字符串
  @split varchar(10)  --分隔符号
)
returns int
as
begin
  declare @location int
  declare @start int
  declare @length int

  set @str=ltrim(rtrim(@str))
  set @location=charindex(@split,@str)
  set @length=1
  while @location<>0
  begin
    set @start=@location+1
    set @location=charindex(@split,@str,@start)
    set @length=@length+1
  end
  return @length
end
调用示例:select dbo.Get_StrArrayLength('78,1,2,3',',')
返回值:4

二、按指定符号分割字符串,返回分割后指定索引的第几个元素,象数组一样方便

CREATE function Get_StrArrayStrOfIndex
(
  @str varchar(1024),  --要分割的字符串
  @split varchar(10),  --分隔符号
  @index int --取第几个元素
)
returns varchar(1024)
as
begin
  declare @location int
  declare @start int
  declare @next int
  declare @seed int

  set @str=ltrim(rtrim(@str))
  set @start=1
  set @next=1
  set @seed=len(@split)
 
  set @location=charindex(@split,@str)
  while @location<>0 and @index>@next
  begin
    set @start=@location+@seed
    set @location=charindex(@split,@start)
    set @next=@next+1
  end
  if @location =0 select @location =len(@str)+1
 --这儿存在两种情况:1、字符串不存在分隔符号 2、字符串中存在分隔符号,跳出while循环后,@location为0,那认为字符串后边有一个分隔符号。
 
  return substring(@str,@start,@location-@start)
end
调用示例:select dbo.Get_StrArrayStrOfIndex('8,9,4',2)
返回值:9

三、结合上边两个函数,象数组一样遍历字符串中的元素

create   function    f_splitstr(@Sourcesql   varchar(8000),@@R_404_4975@rate   varchar(100))  
  returns   @temp   table(F1   varchar(100))  
  as    
  begin  
  declare   @ch   as   varchar(100)  
  set   @Sourcesql=@Sourcesql+@@R_404_4975@rate    
  while(@Sourcesql<>'')  
                  begin  
                  set   @ch=left(@Sourcesql,charindex(',@Sourcesql,1)-1)  
  insert   @temp   values(@ch)  
  set   @Sourcesql=stuff(@Sourcesql,1),'')  
                  end  
  return  
  end  
   

----调用
  select   *   from    dbo.f_splitstr('1,3,')
--结果:
1
2
3

4

--例子

create function [dbo].[split] ( @Sourcesql varchar(8000),@@R_404_4975@rate varchar(10) ) returns @temp table(F1 varchar(100)) as begin     declare @i int     set @Sourcesql = rtrim(ltrim(@Sourcesql))     set @i = charindex(@@R_404_4975@rate,@Sourcesql)     while @i >= 1     begin         if len(left(@Sourcesql,@i-1))>0         begin             insert @temp values(left(@Sourcesql,@i-1))         end         set @Sourcesql=substring(@Sourcesql,@i+1,len(@Sourcesql)-@i)         set @i=charindex(@@R_404_4975@rate,@Sourcesql)     end     if @Sourcesql <> ''         insert @temp values(@Sourcesql)     return end   select * from split(',777,11,888,88,1122,77,00,00',')

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐