• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SQL里类似SPLIT的分割字符串函数
    一,用临时表作为数组
    复制代码 代码如下:

    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
    上一篇:sqlserver 高性能分页实现分析
    下一篇:关于 SQL Server ErrorLog 错误日志说明
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SQL里类似SPLIT的分割字符串函数 SQL,里,类似,SPLIT,的,分割,