zoukankan      html  css  js  c++  java
  • 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) 

    工欲善其事,必先利其器。
  • 相关阅读:
    Shiro权限验证
    5种设计模式整理
    多模块的SpringBoot项目
    Go使用数据库
    使用Go mod
    docker基本使用
    Go的IO操作
    实现一个网盘存储……
    Go的网络编程
    学习golang的历程
  • 原文地址:https://www.cnblogs.com/zhangzhu/p/2547360.html
Copyright © 2011-2022 走看看