一個字串中某一個字元第n次出現的位置的函式

taogchan發表於2014-07-02
create  function f_firstposition(@Str varchar(8000),@StrSep varchar(10),@AppPos int)
returns int
begin
    declare @i int
    declare @ii int
    set @Str=rtrim(ltrim(@Str))
    set @i=1
    select @ii=charindex(@StrSep,@Str)
    if @i=@AppPos
        return @ii
    else
    while @AppPos>@i
    begin
        if charindex(@StrSep,right(@Str,len(@Str)-@ii))<>0
                select @ii=charindex(@StrSep,right(@Str,len(@Str)-@ii))+@ii
        else
                set @ii=0
        set @i=@i+1
    end

    return @ii
end

go
select dbo.f_firstposition('abc,def,ccc,ged',',',1)
go
返回:4
select dbo.f_firstposition('abc,def,ccc,ged',',',2)
go
返回:8
select dbo.f_firstposition('abc,def,ccc,ged',',',3)
go
返回:12
select dbo.f_firstposition('abc,def,ccc,ged',',',4)
go
返回:0

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22392018/viewspace-1203898/,如需轉載,請註明出處,否則將追究法律責任。

相關文章