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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何解决Mac上网速度很慢的问题(多种可能分析)[通俗易懂]

    如何解决Mac上网速度很慢的问题(多种可能分析)[通俗易懂]问题:我发现在我的Mac上上网的速度很慢。第一种分析:问题分析:虽然Mac上的运行速度很慢,但同时在我的两台手机上面的运行速度都比较快。我刚开始怀疑是路由器的问题,如果是路由器的问题,那么手机肯定不会很块,手机也会很慢,可以断定肯定是我的mac设置出了问题,我按个这个步骤寻找,去掉8.8.8.8,问题解决了。将上面的DNS地址8.8.8.8去掉就好了分析8.8.8……

    2025年11月7日
    1
  • W3C 标准_w3c规范

    W3C 标准_w3c规范W3C标准,即一系列标准的集合,他的本质是结构标准语言。就像平时使用的HTML、CSS等都需要遵守这些标准。万维网联盟创建于1994年,是web技术领域最具权威和影响力的国际中立性技术标准机构。它有效促进了web技术相互之间的兼容。就像网页是由三部分组成:结构、表现和行为。那么他对应的标准也分三方面:1.结构化…

    2025年12月15日
    2
  • PAT日志 1146「建议收藏」

    PAT日志 1146「建议收藏」顽强的小白1146TopologicalOrder(25分)ThisisaproblemgivenintheGraduateEntranceExamin2018:WhichofthefollowingisNOTatopologicalorderobtainedfromthegivendirectedgraph?Nowyouare…

    2022年6月9日
    29
  • Qt的双缓冲技术(double buffering)

    Qt的双缓冲技术(double buffering)Qt的双缓冲技术(doublebuffering)是Qt绘画机制的一部分,是一种在Qt4中被全面采用的技术。其核心是:把一个窗口部件渲染到一个脱屏pixmap(off-screenpixmap)中,然后再把这个pixmap复制到显示屏幕上。这样做的目的是用于消除屏幕的闪烁并且因而界面会显得更漂亮。Qt4中,Qt会自动处理这些情况,所以在普通的绘画中,我们不必要关注这些内容。QT取消双

    2022年5月21日
    47
  • 2021版idea激活码99年_在线激活

    (2021版idea激活码99年)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~K…

    2022年3月22日
    125
  • 激活成功教程资料大全「建议收藏」

    激活成功教程资料大全「建议收藏」激活成功教程资料大全顶啊!!! DFCG官方论坛http://www.chinadfcg.com/龙族联盟论坛http://www.chinadforce.com/index.php中国狂热激活成功教程联盟-梦想家园社区http://www.5icrack.com/bbs/index.php风飘雪|加密与解密实战攻略|最酷激活成功教程教学,带你轻松进入激活成功教程的殿堂http://www.hx007.com/f

    2022年10月8日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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