sqlserver中自定义字符串拆分函数

create FUNCTION [dbo].[Split]
(
 @Content NVARCHAR(100),
 @Seperator NVARCHAR(10)
)
RETURNS  NVARCHAR(100)

AS
BEGIN
 DECLARE @ci INT,--current index
 @ni INT,--next index
 @LenOfContent INT;
 declare @re varchar(100);
 DECLARE @temp VARCHAR(100);

 SET @LenOfContent=DATALENGTH(@Content);
        SET @ci=1;
        SET @ni=CHARINDEX(@Seperator,@Content);--1 based  ni=2
 SET @re = ''; 
 SET @temp = ''; 

        WHILE(@ni>0)
        BEGIN
  IF(@ni>=@ci+1)
  BEGIN
   IF @re = ''
   BEGIN
    SELECT @temp = industry FROM scrm_sys_industry WHERE id = SUBSTRING(@Content,@ci,@ni-@ci)
    SET @re = @temp;
   END
   ELSE
   BEGIN
    SELECT @temp = industry FROM scrm_sys_industry WHERE id = SUBSTRING(@Content,@ci,@ni-@ci)
    SET @re = @re + ',' + @temp;
   END

  END
  SET @ci=@ni+1;
  SET @ni=CHARINDEX(@Seperator,@Content,@ci);
 END
 IF(@ci<=@LenOfContent)
 BEGIN
  SELECT @temp = industry FROM scrm_sys_industry WHERE id = SUBSTRING(@Content,@ci,@LenOfContent+1-@ci)
  set @re = @re + ',' + @temp;
 END
 RETURN @re;
END

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值