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

今天博客园中看到一朋友写的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






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值