当前位置: 数据库>sqlserver
自己写的sql 字符串分割函数 Split
来源: 互联网 发布时间:2014-08-29
本文导语: 问题描述: 因为审核或删除操作是在存储过程进行的,所以,就打算将选中的数据的主键拼成字符串,传到存储过程进行分离,再继续处理。 C#中和JavaScript中都有相应的分离字符串的Split函数,就想当然的以为SQL中也会有类...
问题描述:
因为审核或删除操作是在存储过程进行的,所以,就打算将选中的数据的主键拼成字符串,传到存储过程进行分离,再继续处理。
C#中和JavaScript中都有相应的分离字符串的Split函数,就想当然的以为SQL中也会有类似的函数,结果查了半天的MSSQL帮助文档,也没找到。
下面说说俺的设计思路:
在需要分解的字符串中,如果存在指定的分隔符,则将第一个分隔符前面的字符串取出,存入表内,然后在需要分解的字符串中将已取出的字符串及第一个分隔符删除,然后继续下一次分解(如果还存在指定的分隔符,就分解)
代码如下:
-- =============================================
-- Author: Henson
-- Create date: 2011-04-20
-- Description: 字符串分离函数
-- =============================================
ALTER FUNCTION [dbo].[Split]
(
@strText varchar(3000),--待分离的原字符串
@strSplit varchar(100)--分隔符
)
RETURNS @temp Table
(
ID int IDENTITY PRIMARY KEY,
SingleVal varchar(1000)
)
AS
BEGIN
Declare @intLen int --用来存储待分离原字符串长度
Declare @intSplitLen int --分隔符长度
Declare @intIndex int --用来存储分离字符串在原字符串的位置
Declare @strVal varchar(1000)--用来存储分离出来后的字符串
--获取原字符串的长度
Set @intLen = LEN(RTRIM(LTRIM(@strText)))
Set @intSplitLen = LEN(RTRIM(LTRIM(@strSplit)))
--原字符串不为空,才继续分离
If(@intLen > 0)
Begin
--循环原字符串,直至原字符串被分离完毕
While CHARINDEX(@strSplit,@strText)>0
Begin
--获取分离字符串在原字符串的位置
Set @intIndex = CHARINDEX(@strSplit,@strText)
--获取分离出的字符串,并插入表中
Set @strVal = RTRIM(LTRIM(LEFT(@strText,@intIndex-1)))
if(LEN(@strVal)>0)
Begin
Insert Into @temp (SingleVal) values(@strVal)
End
--分离后,将分离出的字符串(包括分隔符)从原字符串中删除
Set @strText = Substring(@strText,@intIndex+@intSplitLen,@intLen-@intIndex)
--重新设置原字符串的长度
Set @intLen = LEN(@strText)
End
--如果分离后的原字符串依然不为空,则也应该插入表中
if(LEN(RTRIM(LTRIM(@strText)))>0)
Begin
Insert Into @temp (SingleVal) values(@strText)
End
End
return
END
-- Author: Henson
-- Create date: 2011-04-20
-- Description: 字符串分离函数
-- =============================================
ALTER FUNCTION [dbo].[Split]
(
@strText varchar(3000),--待分离的原字符串
@strSplit varchar(100)--分隔符
)
RETURNS @temp Table
(
ID int IDENTITY PRIMARY KEY,
SingleVal varchar(1000)
)
AS
BEGIN
Declare @intLen int --用来存储待分离原字符串长度
Declare @intSplitLen int --分隔符长度
Declare @intIndex int --用来存储分离字符串在原字符串的位置
Declare @strVal varchar(1000)--用来存储分离出来后的字符串
--获取原字符串的长度
Set @intLen = LEN(RTRIM(LTRIM(@strText)))
Set @intSplitLen = LEN(RTRIM(LTRIM(@strSplit)))
--原字符串不为空,才继续分离
If(@intLen > 0)
Begin
--循环原字符串,直至原字符串被分离完毕
While CHARINDEX(@strSplit,@strText)>0
Begin
--获取分离字符串在原字符串的位置
Set @intIndex = CHARINDEX(@strSplit,@strText)
--获取分离出的字符串,并插入表中
Set @strVal = RTRIM(LTRIM(LEFT(@strText,@intIndex-1)))
if(LEN(@strVal)>0)
Begin
Insert Into @temp (SingleVal) values(@strVal)
End
--分离后,将分离出的字符串(包括分隔符)从原字符串中删除
Set @strText = Substring(@strText,@intIndex+@intSplitLen,@intLen-@intIndex)
--重新设置原字符串的长度
Set @intLen = LEN(@strText)
End
--如果分离后的原字符串依然不为空,则也应该插入表中
if(LEN(RTRIM(LTRIM(@strText)))>0)
Begin
Insert Into @temp (SingleVal) values(@strText)
End
End
return
END
说明:
(分隔符允许是多位的)
按一般的习惯来讲,在组织多个字符串时,一般都是这种写法:strKeys += strSingleKey + ",";
所以可能最终该字符串可能会以逗号结尾,如果组织完成后,将结尾的逗号去掉了,那就不会以逗号结尾,所以,在循环分解完成后,如果剩下的原字符串中(去除左右空格后),如果还有内容 ,则也应该存入表中。
才疏学浅,不胜酒力,哈哈,难免有bug,欢迎指正,有问题请进官方QQ群:161228069 进行交流。