sql实现split函数的脚本

2022-05-24 0 1,190

复制代码 代码如下:

–创建一个函数,函数中有两个参数

Create FUNCTION [dbo].[SplitToTable]

(

@SplitString nvarchar(max),–输入的字符串

@Separator nvarchar(10)=’ ‘–分割条件

)

–返回的数据为一个表

RETURNS @SplitStringsTable TABLE

(

[id] int identity(1,1),

[value] nvarchar(max)

)

AS

BEGIN

DECLARE @CurrentIndex int;–当前索引

DECLARE @NextIndex int;–下一个索引

DECLARE @ReturnText nvarchar(max);–返回内容

SELECT @CurrentIndex=1;–设置当前索引初始值为1

–当当前索引小于字符串长度时,执行循环体

WHILE(@CurrentIndex<=len(@SplitString))

BEGIN

–CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。CHARINDEX函数调用方法如下:

–CHARINDEX ( expression1 , expression2 [ , start_location ] )

— Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。

SELECT @NextIndex=charindex(@Separator,@SplitString,@CurrentIndex);

IF(@NextIndex=0 OR @NextIndex IS NULL)

SELECT @NextIndex=len(@SplitString)+1;

–函数用法:SUBSTRING ( expression, start, length )

SELECT @ReturnText=substring(@SplitString,@CurrentIndex,@NextIndex-@CurrentIndex);

INSERT INTO @SplitStringsTable([value]) VALUES(@ReturnText);

SELECT @CurrentIndex=@NextIndex+1;

END

RETURN;

END

go

–测试函数

select * FROm dbo.SplitToTable(‘a,b,c,d,e,f,g’, ‘,’)

免责声明:
1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

NICE源码网 MsSql sql实现split函数的脚本 https://www.niceym.com/61835.html