• sql split


    SQL对字符串的处理能力比较弱,比如我要循环遍历象1,2,3,4,5这样的字符串,如果用数组的话,遍历很简单,但是T-SQL不支持数组,所以处理下来比较麻烦。下边的函数,实现了象数组一样去处理字符串。
    一,用临时表作为数组
    create   function   f_split(@c   varchar(2000),@split   varchar(2))  
      returns   @t   table(col   varchar(20))  
      as  
        begin  
       
          while(charindex(@split,@c)<>0)  
            begin  
              insert   @t(col)   values   (substring(@c,1,charindex(@split,@c)-1))  
              set   @c   =   stuff(@c,1,charindex(@split,@c),'')  
            end  
          insert   @t(col)   values   (@c)  
          return  
        end  
      go  
       
      select   *   from   dbo.f_split('dfkd,dfdkdf,dfdkf,dffjk',',')  
       
      drop   function   f_split 
      col                                      
      --------------------    
      dfkd  
      dfdkdf  
      dfdkf  
      dffjk  
       
      (所影响的行数为   4   行)


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

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

    declare @str varchar(50)
    set @str='1,2,3,4,5'
    declare @next int 
    set @next=1
    while @next<=dbo.Get_StrArrayLength(@str,',')
    begin
     print dbo.Get_StrArrayStrOfIndex(@str,',',@next)
     set @next=@next+1
    end

    调用结果:
    1
    2
    3
    4
    5

    CREATE function [dbo].[f_split](@SourceSql varchar(8000),@StrSeprate varchar(10))
    returns @temp table(id varchar(100))
    --实现split功能 的函数
    as
    begin
    declare @i int
    set @SourceSql=rtrim(ltrim(@SourceSql))
    set @i=charindex(@StrSeprate,@SourceSql)
    while @i>=1
    begin
    insert @temp values(left(@SourceSql,@i-1))
    set @SourceSql=substring(@SourceSql,@i+1,len(@SourceSql)-@i)
    set @i=charindex(@StrSeprate,@SourceSql)

    end
    if @SourceSql<>'\'
    insert @temp values(@SourceSql)
    return
    end

  • 相关阅读:
    Kubernetes源码client-go的workqueue
    (转)Golang语言heap剖析及利用heap实现优先级队列
    (转)Kubernetes GC设计原则
    Kubernetes kubefed使用Cluster Selector
    使用kubeadm添加新节点到集群及相关问题解决
    Kubeadm颁发证书延迟到10年
    kubeadm升级Kubernetes证书
    混合kubebuilder与code generator编写CRD
    (转)Go项目的vendor目录是否需要提交?看这一篇就知道了
    Java 将Excel转为et和ett格式
  • 原文地址:https://www.cnblogs.com/zwei1121/p/1500448.html
Copyright © 2020-2023  润新知