--SQL Server Split函数 --Author: sq --说明:被分割后的字段为:short_str --支持分割符多字节 --使用方法
--Select * FROM splits('1203401230105045','0')
--Select * FROM splits('1203401230105045','123')
--select t1.id,t2.short_str from Table1 as t1 cross apply Splits(t1.name,',') as t2
-- cross apply 为2005以上版本才有的函数
CREATE FUNCTION splits(@Long_str NVARCHAR(MAX),@split_str NVARCHAR(100)) RETURNS @tmp TABLE( ID inT IDENTITY PRIMARY KEY, short_str NVARCHAR(MAX) ) AS BEGIN DECLARE @short_str NVARCHAR(MAX),@split_str_length int,@split_str_Position_Begin int SET @split_str_length = LEN(@split_str) SET @Long_str=REPLACE(REPLACE(@Long_str,CHAR(10),''),CHAR(13),'') IF CHARINDEX(@split_str,@Long_str)=1 SET @Long_str=STUFF(@Long_str,1,@split_str_length,'') IF CHARINDEX(@split_str,@Long_str)=0 INSERT INTO @tmp SELECT @Long_str ELSE BEGIN WHILE 1>0 BEGIN SET @split_str_Position_Begin = CHARINDEX(@split_str,@Long_str) SET @short_str=LEFT(@Long_str,@split_str_Position_Begin-1) IF @short_str<>'' INSERT INTO @tmp SELECT @short_str SET @Long_str=STUFF(@Long_str,1,@split_str_Position_Begin+@split_str_length-1,'') SET @split_str_Position_Begin = CHARINDEX(@split_str,@Long_str) IF @split_str_Position_Begin=0 BEGIN IF LTRIM(@Long_str)<>'' INSERT INTO @tmp SELECT @Long_str BREAK END END END RETURN END