Sql实现Split

Sql实现Split

create function [dbo].[Get_StrArrayLength]
(
 @str varchar(max),  –要分割的字符串
 @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)
 –设置分隔后的字符串长度为1
 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

 

 drop function [dbo].[Get_StrArrayStrOfIndex]
go
create function [dbo].[Get_StrArrayStrOfIndex]
(
 @str varchar(max),  –要分割的字符串
 @split varchar(10),  –分隔符号
 @index int –取第几个元素
)
returns varchar(1024)
as
begin
 declare @location int
 declare @start int
 declare @next int
 declare @seed int
 declare @pos int
 if @index<=0
 return ”
 set @str=ltrim(rtrim(@str))
 set @start=1
 set @next=1
 set @pos=1
 set @seed=len(@split)
 set @location=charindex(@split,@str)
 while @location<>0 and @index>@next and @pos<@index
 begin
   set @start=@location+@seed
   set @location=charindex(@split,@str,@start)
   set @next=@next+1
   set @pos=@pos+1
 end
 if @location =0
 if @pos<>@index
  return ”
 else
  select @location =len(@str)+1
–这儿存在两种情况:1、字符串不存在分隔符号 2、字符串中存在分隔符号,跳出while循环后,@location为0,那默认为字符串后边有一个分隔符号。
 return substring(@str,@start,@location-@start)
end

declare @id varchar(30)
select @id=dbo.Get_StrArrayStrOfIndex(‘4321,2223,333,5554′,’,’,2)

 

我的改进版本,可像Hashtable一样访问

drop function [dbo].[Get_ArrayStrOfName]
Go

create function [dbo].[Get_ArrayStrOfName]
(
    @str varchar(5000),  –要分割的字符串
    @split varchar(1),  –分隔符号
    @itemSplit varchar(1), –元素分割符
    @item varchar(20)   –取哪个元素
)
returns varchar(1024)
As
Begin
    declare @location int            –找到子串的位置
    declare @tempItem varchar(50)        –当前项
    declare @tempItemName varchar(20)    –当前项的名称
    set @str=ltrim(rtrim(@str))
    set @tempItem=”
    set @tempItemName=”
while len(@str)>0
Begin
    —–找到一个子项–
    set @location=charindex(@split,@str,1)
    if @location>0
        Begin
                set @tempItem=substring(@str,1,@location-1)
                set @str=substring(@str,@location+1,len(@str))
        End
    Else
        Begin
            set @tempItem=@str
            set @str=”
        end    
    ———-判断当前子项的名称————–
    set @location=charindex(@itemSplit,@tempItem,1)
    if @location>0
        Begin
            set @tempItemName=substring(@tempItem,1,@location-1)
            if  @tempItemName=@item
                return substring(@tempItem,@location+1,len(@tempItem))
        End
End
    return ”
End
Go

declare @id varchar(30)
select @id=dbo.Get_ArrayStrOfName(‘ff@4321,ffg@2223,ggg@333,ddd@5554’, ‘,’, ‘@’, ‘ff’)
print @id

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/110915.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • C# 实现 FFT 正反变换 和 频域滤波

    C# 实现 FFT 正反变换 和 频域滤波

  • burpsuite小米手机抓包_Android 7.0+手机burpsuite抓包https

    burpsuite小米手机抓包_Android 7.0+手机burpsuite抓包https记录一下以后可能会遇到的此类问题的解决方案。方法1:系统证书目录:/system/etc/security/cacerts/其中的每个证书的命名规则如下:.文件名是一个Hash值,而后缀是一个数字。文件名可以用下面的命令计算出来:opensslx509-subject_hash_old-in后缀名的数字是为了防止文件名冲突的,比如如果两个证书算出的Hash值是一样的话,那么一个证书的后缀名…

  • 求和符号的运用_求和符号的性质

    求和符号的运用_求和符号的性质文章向导从单重求和谈起(定义与基本性质)多重求和(二重情况)求和的实际应用(等比级数)引言:  求和符号经常活跃于数学或工程实际问题中,特别是处于多重求和情况时,连用的求和符号存在运算的优先顺序,有时我们可以直接互换不同求和符号之间的位置,而有时不同的位置则代表不同的求和意义。因此,关于求和符号∑的问题还是很有必要进行细致讨论一番。一、从单重求和谈起  我们通过一个例子来回顾下求…

    2022年10月12日
  • 使用 HTML、CSS 和 JS 的简单倒数计时器[通俗易懂]

    使用 HTML、CSS 和 JS 的简单倒数计时器[通俗易懂]JavaScript倒数计时器用于各种电子商务和建设中的网站,以使用户保持最新状态。我们在不同类型的电子商务网站上看到,在任何产品或优惠到达之前的某个时间开始倒计时。在本文中,我使用简单的JavaScript代码创建了一个倒数计时器和你分享。您可以观看它的现场演示以了解它是如何工作的。如果您知道如何创建数字时钟,那么创建这样的项目就会容易得多。您可以在此处提前安排特定日期或时间。然后,在JavaScript代码的帮助下,从那个时间减去当前时间,减法每秒减少一次。正如您在上图中所看到的,我在这

  • Linux awk统计日志中出现过的IP(或出现次数最多的N个IP)

    Linux awk统计日志中出现过的IP(或出现次数最多的N个IP)

  • zookeeper系列学习——(1)zookeeper的简单介绍

    这一篇大概整理一下zookeeper的一下基本的知识点,不能自己研究出新的技术,就先看别人造出来的轮子! 我一直在模仿,从未有创新!但我相信从模仿开始,总归是有成长和进步的! 首先学习一个新的技术,看官方文档是最好的一种方式。对我来说不仅可以学习技术,还可以提升一下自己的英语能力。 [zookeeper官方网站(http://zookeeper.apache.org/)。Zookeeper中文

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号