ITPub博客

首页 > 数据库 > 数据库开发技术 > 字符串分割自定义函数(SQL)

字符串分割自定义函数(SQL)

原创 数据库开发技术 作者:wghao 时间:2007-12-03 14:37:29 0 删除 编辑
修改以前写的一个字符串分割自定义函数出现的bug.[@more@]今天博客园中看到一朋友写的SQL中分割字符串函数:
http://www.cnblogs.com/czwand/archive/2007/11/21/966910.html
在回帖中看到一朋友说到:
select * from dbo.split('01__02__03','__')
发生错误,返回的结果不是我们原本要的结果:
-------------------
--想要的结果
01
02
03
-----------------
--实际结果:
01
_02
_03

以前我也写过类似的字符串分割自定义函数,也没有想过上面出现的这样问题。
我原来的函数是这样的:

/*
StringToTable
*/
CREATE FUNCTION StringToTable(@StringX varchar(8000),@Split nvarchar(10))
RETURNS @TableResult TABLE(TableID nvarchar(20))
AS
BEGIN
DECLARE @Index int
SET @Index=CHARINDEX(@Split,@StringX,1)
WHILE (@Index>=1)
BEGIN
INSERT INTO @TableResult SELECT LEFT(@StringX,@Index-1)
SELECT

@StringX=RIGHT(@StringX,LEN(@StringX)-@Index),@Index=CHARINDEX(@Split,@StringX,1)
END
IF(@StringX<>'') INSERT INTO @TableResult SELECT @StringX
RETURN
END



使用类似的select * from dbo.split('01__02__03','__') 一样出问题。
经过一下的修改就可以了,修改后程序为:

/*
StringToTable
*/
CREATE FUNCTION StringToTable(@StringX varchar(8000),@Split nvarchar(10))
RETURNS @TableResult TABLE(TableID nvarchar(20))
AS
BEGIN
DECLARE @Index int
DECLARE @LenIndex int
SELECT @LenIndex=LEN(@Split),@Index=CHARINDEX(@Split,@StringX,1)
WHILE (@Index>=1)
BEGIN
INSERT INTO @TableResult SELECT LEFT(@StringX,@Index-1)
SELECT

@StringX=RIGHT(@StringX,LEN(@StringX)-@Index-@LenIndex+1),@Index=CHARINDEX(@Split,@Stri

ngX,1)
END
IF(@StringX<>'') INSERT INTO @TableResult SELECT @StringX
RETURN
END

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7764484/viewspace-987702/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 一条LIKE查询问题
请登录后发表评论 登录
全部评论

注册时间:2007-12-19

  • 博文量
    57
  • 访问量
    231535