不用XML的字符串切分表值函数

前端之家收集整理的这篇文章主要介绍了不用XML的字符串切分表值函数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
--先增加辅助表
SET NOCOUNT ON
DECLARE @i INT,@iMax INT
SET @iMax=100000
INSERT INTO spt_values (number) VALUES(1)
WHILE 1=1 
BEGIN
    SELECT @i=MAX(number) FROM spt_values
    IF @i<=@imax/2
    BEGIN
        INSERT INTO spt_values (number)
        SELECT @i+number FROM spt_values ORDER BY number
    END
    ELSE
    BEGIN
        INSERT INTO spt_values (number)
        SELECT TOP( @iMax-@i ) @i+number FROM spt_values ORDER BY number
        BREAK;
    END
END
GO
--创建表值函数
IF OBJECT_ID('[dbo].[Fun_SplitStr]') IS NOT NULL
	DROP FUNCTION [dbo].[Fun_SplitStr]
GO
-- =============================================
-- Author:		yenange
-- Create date: 2017-01-11
-- Description:	字符串切分函数(以逗号为切分符)
-- =============================================
CREATE FUNCTION [dbo].[Fun_SplitStr] 
(	
	@str NVARCHAR(MAX)
)
RETURNS TABLE 
AS
RETURN 
(
	SELECT SUBSTRING(@str,b.number,CHARINDEX(',',@str + ',b.number) -b.number) AS item
	FROM   dbo.spt_values b
	WHERE  
		   
		   b.number BETWEEN 1 AND LEN(@str)
		   AND SUBSTRING(',' + @str,1) = ','
		   --AND ISNULL(SUBSTRING(@str,b.number) -b.number),'')!=''
)

用 master..spt_values 也行, 但最大才2047, 不够用。

与xml那个切分函数对比, 效率上也没有优势。 不过也算另一种思维, 特此记之。

猜你在找的XML相关文章