1

上下文:SQL Server 2000

我写了一个UDF,它给了我两个其他文本之间的文本,即

CREATE FUNCTION dbo.StrBetween 
(
    @Text nvarchar(4000),
    @Lhs nvarchar(4000),
    @Rhs nvarchar(4000)
)
RETURNS nvarchar(4000)
AS
BEGIN
    DECLARE @LhsOffset INT;
    DECLARE @RhsOffset INT;
    DECLARE @Result NVARCHAR(4000);

    SET @LhsOffset = CHARINDEX( @Lhs, @Text );
    IF @LhsOffset = 0 
    BEGIN
        RETURN @Text;
    END
    SET @Result = SUBSTRING( @Text, @LhsOffset+1, LEN(@Text)-LEN(@Lhs));
    SET @RhsOffset = CHARINDEX( @Rhs, @Result );
    IF @RhsOffset = 0 
    BEGIN
        RETURN @Result;
    END
    SET @Result = SUBSTRING( @Result, 1, @RhsOffset - 1 );
    RETURN @Result;
END

如果我有,这在 SQL 查询分析器中可以正常工作,比如说,

SELECT dbo.StrBetween('dog','d','g')

但是,当我将一列作为第一个参数的值传递时,我没有得到任何响应。例如,

SELECT [TEST].[dbo].StrBetween(Referrer,'//', '/') as tst FROM tblTest 

Referrer 被声明为一个 nvarchar 字段。我是 T-SQL 的新手。我没有看到什么明显的东西?

4

1 回答 1

3

这不是调用的问题 - 这是一个逻辑问题,而且您的@Rhs价值是价值的一部分@Lhs

SET @Result = SUBSTRING( @Text, @LhsOffset+1, LEN(@Text)-LEN(@Lhs));

这是删除字符串的第一个字符@Lhs。但是,由于第二个字符是/,这就是您的@Rhs匹配项正在搜索的内容,它会立即在位置 1 找到它,因此您会得到一个空字符串。

相反,请尝试:

SET @Result = SUBSTRING( @Text, @LhsOffset+LEN(@Lhs), 4000);

您不必精确计算长度。如果您要求 4000 个字符,而字符串只有 12 个字符长,SUBSTRING最多会给您 12 个字符。所以不要费心计算新的长度。

于 2013-02-14T13:41:53.783 回答