• SQL分割字符串2


    create function [dbo].[SplitString]

    (
        @Input nvarchar(max),
        @Separator nvarchar(max)=',',
        @RemoveEmptyEntries bit=1 ,
        @position int
    )
    returns @TABLE table
    (
        [Id] int identity(1,1),
        [Value] nvarchar(max)
    )
    as
    begin
        declare @Index int, @Entry nvarchar(max)
        set @Index = charindex(@Separator,@Input)
        set @Input = @Input + @Separator
        
        declare @count int
        set @count = 1
        while (@Index>0)
        begin
            set @Entry=ltrim(rtrim(substring(@Input, 1, @Index-1)))
            
            if (@RemoveEmptyEntries=0) or (@RemoveEmptyEntries=1 and @Entry<>'')
                begin
                  if @count = @position
                    begin
                       insert into @TABLE([Value]) Values(@Entry)
                    end
                end

            set @Input = substring(@Input, @Index+datalength(@Separator)/2, len(@Input))
            set @Index = charindex(@Separator, @Input)
            set @count =  @count + 1;
        end
       
        return
    end

    ------------------------------

         select  [Value] from [dbo].[SplitString2]('2012-12-25', '-', 1,1)
         select  [Value] from [dbo].[SplitString2]('2012-12-25', '-', 1,2)
         select  [Value] from [dbo].[SplitString2]('2012-12-25', '-', 1,3) 

    工欲善其事,必先利其器。
  • 相关阅读:
    bfs两种记录路径方法
    次小生成树
    2018 ICPC 区域赛 焦作场 D. Keiichi Tsuchiya the Drift King(计算几何)
    数组分组
    POJ
    数位DP详解
    2018ICPC青岛 E
    HDU
    Google工程师打造Remix OS系统 桌面版安卓下载
    使用angular封装echarts
  • 原文地址:https://www.cnblogs.com/zhangzhu/p/2547360.html
Copyright © 2020-2023  润新知