Sql分隔字符串方法--split

本文介绍了一个SQL Server中用于分割字符串的自定义函数。该函数可以将一个包含多个值的大字符串按照指定的分隔符进行分割,并返回第n个元素。通过这个函数,可以方便地处理那些使用逗号或其他字符分隔的数据。
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
--DEClARE @str varchar(500)='a,b2,v5,d3,ew,2,3,dd'

--select  [dbo].[split](@str,',',8)

CREATE FUNCTION [dbo].[split]
(@str nvarchar(4000),@code varchar(10),@no int )  
RETURNS varchar(200)
AS  
BEGIN

declare @intLen int
declare @count int
declare @indexb  int
declare @indexe  int
set @intLen=len(@code)
set @count=0
set @indexb=1


if @no=0
  if charindex(@code,@str,@indexb)<>0
     return left(@str,charindex(@code,@str,@indexb)-1)
  else
     return @str

while charindex(@code,@str,@indexb)<>0
  begin
       set @count=@count+1
       if @count=@no
         break
       set @indexb=@intLen+charindex(@code,@str,@indexb)
  end


if @count=@no
  begin

      set @indexe=@intLen+charindex(@code,@str,@indexb)
          if charindex(@code,@str,@indexe)<>0
             return substring(@str,charindex(@code,@str,@indexb)+len(@code),charindex(@code,@str,@indexe)-charindex(@code,@str,@indexb)-len(@code))
          else
             return right(@str,len(@str)-charindex(@code,@str,@indexb)-len(@code)+1)

  end

return NULL

END


--select dbo.split("列名",',',0)

 

转载于:https://www.cnblogs.com/elves/p/3522110.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值