阅读 179

SQLserver将字符串分割为数组的函数(sql语句分割字符串)

一、按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果。CREATE function Get_StrArrayLength(
  @str varchar(1024),  --要分割的字符串
  @split varchar(10)  --分隔符号)returns intasbegin
  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 @lengthend调用示例:select dbo.Get_StrArrayLength('78,1,2,3',',')返回值:4二、按指定符号分割字符串,返回分割后指定索引的第几个元素,象数组一样方便CREATE function Get_StrArrayStrOfIndex(
  @str varchar(1024),  --要分割的字符串
  @split varchar(10),  --分隔符号
  @index int --取第几个元素)returns varchar(1024)asbegin
  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,@str,@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)返回值:9select dbo.Get_StrArrayStrOfIndex('PO-2100-5LLSJFDSL','-',3)  -- 5LLSJFDSL  select dbo.Get_StrArrayStrOfIndex('PO-2100/5LLSJFDSL','/',1)  --PO-2100三、结合上边两个函数,象数组一样遍历字符串中的元素create   function   f_splitstr(@SourceSql   varchar(8000),@StrSeprate   varchar(100))   
  returns   @temp   table(F1   varchar(100))   
  as     
  begin   
  declare   @ch   as   varchar(100)   
  set   @SourceSql=@SourceSql+@StrSeprate     
  while(@SourceSql<>'')   
                  begin   
                  set   @ch=left(@SourceSql,charindex(',',@SourceSql,1)-1)   
  insert   @temp   values(@ch)   
  set   @SourceSql=stuff(@SourceSql,1,charindex(',',@SourceSql,1),'')   
                  end   
  return   
  end   
    ----调用
  select   *   from   dbo.f_splitstr('1,2,3,4',',') --结果:1234Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1639974

SQLserver字符串分割函数 - 翅膀 - 博客园

sqlserver 分割字符串为数组_Z_Y_J_1_2_3的专栏-CSDN博客

标签:set,数组,--,SQLserver,start,location,str,字符串,SourceSql
来源: https://blog.csdn.net/qq_18932003/article/details/121438163


文章分类
代码人生
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐