码迷,mamicode.com
首页 > 数据库 > 详细

sqlserver 自定义字符串分割函数.

时间:2015-06-04 15:41:34      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:

--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

 

sqlserver 自定义字符串分割函数.

标签:

原文地址:http://www.cnblogs.com/sunqiang/p/4551751.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!