数据库自定义表值函数Split(@LongStr, @SplitStr, @IsDistinct )
2014-12-31 17:18
281 查看
CREATE FUNCTION [dbo].[F3_Split](@LongStr VARCHAR(MAX),@SplitStr VARCHAR(100),@IsDistinct BIT)
RETURNS @RTable TABLE(ID INT IDENTITY PRIMARY KEY,ShortStr VARCHAR(MAX))
AS BEGIN
IF ISNULL(@LongStr,'')='' --表达式为空或NULL直接返回空表
RETURN
IF ISNULL(@SplitStr,'')='' --分隔符为空直接返回一条记录的表(存放表达式)
BEGIN
INSERT INTO @RTable(ShortStr) SELECT @LongStr
RETURN
END
DECLARE @Split_len INT
DECLARE @LongStr_len INT
SET @Split_len=LEN(@SplitStr) --分隔符的长度
SET @LongStr_len=LEN(@LongStr) --目前表达式的长度
WHILE CHARINDEX(@SplitStr,@LongStr)>0
BEGIN
DECLARE @ShortStr VARCHAR(1000) --分割后的字符串
SET @ShortStr=SUBSTRING(@LongStr,1,CHARINDEX(@SplitStr,@LongStr)-1) --每次从第1个位置开始取分隔符所在的位置-1为一截
SET @LongStr=SUBSTRING(@LongStr,CHARINDEX(@SplitStr,@LongStr)+@Split_len,(@LongStr_len-LEN(@ShortStr)-@Split_len)) --变换表达式的值为剩下的
SET @LongStr_len=LEN(@LongStr) --变换表达式的长度
IF @ShortStr<>'' AND @IsDistinct=1
INSERT INTO @RTable(ShortStr) SELECT @ShortStr
WHERE NOT EXISTS(SELECT 1 FROM @RTable WHERE ShortStr=@ShortStr) --将分割出来的字符串放入表中
ELSE IF @ShortStr<>''
INSERT INTO @RTable(ShortStr) SELECT @ShortStr
END
IF @LongStr<>'' AND @IsDistinct=1 --如果最后一截没有分隔符,则直接进入表中
INSERT INTO @RTable(ShortStr) SELECT @LongStr
WHERE NOT EXISTS(SELECT 1 FROM @RTable WHERE ShortStr=@LongStr)
ELSE IF @LongStr<>''
INSERT INTO @RTable(ShortStr) SELECT @LongStr
RETURN
END
RETURNS @RTable TABLE(ID INT IDENTITY PRIMARY KEY,ShortStr VARCHAR(MAX))
AS BEGIN
IF ISNULL(@LongStr,'')='' --表达式为空或NULL直接返回空表
RETURN
IF ISNULL(@SplitStr,'')='' --分隔符为空直接返回一条记录的表(存放表达式)
BEGIN
INSERT INTO @RTable(ShortStr) SELECT @LongStr
RETURN
END
DECLARE @Split_len INT
DECLARE @LongStr_len INT
SET @Split_len=LEN(@SplitStr) --分隔符的长度
SET @LongStr_len=LEN(@LongStr) --目前表达式的长度
WHILE CHARINDEX(@SplitStr,@LongStr)>0
BEGIN
DECLARE @ShortStr VARCHAR(1000) --分割后的字符串
SET @ShortStr=SUBSTRING(@LongStr,1,CHARINDEX(@SplitStr,@LongStr)-1) --每次从第1个位置开始取分隔符所在的位置-1为一截
SET @LongStr=SUBSTRING(@LongStr,CHARINDEX(@SplitStr,@LongStr)+@Split_len,(@LongStr_len-LEN(@ShortStr)-@Split_len)) --变换表达式的值为剩下的
SET @LongStr_len=LEN(@LongStr) --变换表达式的长度
IF @ShortStr<>'' AND @IsDistinct=1
INSERT INTO @RTable(ShortStr) SELECT @ShortStr
WHERE NOT EXISTS(SELECT 1 FROM @RTable WHERE ShortStr=@ShortStr) --将分割出来的字符串放入表中
ELSE IF @ShortStr<>''
INSERT INTO @RTable(ShortStr) SELECT @ShortStr
END
IF @LongStr<>'' AND @IsDistinct=1 --如果最后一截没有分隔符,则直接进入表中
INSERT INTO @RTable(ShortStr) SELECT @LongStr
WHERE NOT EXISTS(SELECT 1 FROM @RTable WHERE ShortStr=@LongStr)
ELSE IF @LongStr<>''
INSERT INTO @RTable(ShortStr) SELECT @LongStr
RETURN
END
相关文章推荐
- 数据库快照,自定义函数与计算列
- Sql Server中自定义类似Split功能的函数
- 数据库树型结构中获取目录串的高性能方法,sys_connect_by_path与自定义函数性能对比
- str_split() 函数
- oracle 返回结果集的自定义函数 数据库管道
- 自定义distinct 函数
- 数据库自定义函数
- SQL自定义函数split 将数组(分隔字符串)返回阵列(表)
- SQL Server 2005 自定义split 函数
- str_split 分隔中文出现乱码 替代函数
- [SqlServer]数据库中自定义拆分字符串函数Split()
- 数据库自定义函数学习
- asp中自定义截取字段函数StrLeft()
- sql server过滤字符串中空格的自定义函数f_trimstr()
- sql server 自定义split(分割)函数
- 数据库快照,自定义函数与计算列
- SqlServer数据库自定义Split()函数
- 自己写的一个数据库自定义函数实例
- 自己写的一个数据库自定义函数实例
- 数据库split字符串分割和trim去除空格的表值函数