无法在桌面上调用方法?表变量

时间:2013-11-19 08:23:29

标签: sql sql-server table-valued-parameters table-variable

我正在尝试将外部应用放在表变量上,但我收到如下错误

无法在桌面上调用方法。

我有Split功能,将字符串拆分为一定长度

CREATE FUNCTION Split(@String varchar(MAX), @SplitLength int) 
RETURNS @Result TABLE (Splited varchar(MAX))
AS
BEGIN

Declare @Cnt int
    Set @Cnt = FLOOR((len(@String)/@SplitLength));

   While @Cnt!=0
    Begin
     SET @Cnt=@Cnt-1;
        While len(@String)>@SplitLength 
        Begin

         INSERT INTO @Result  VALUES (SUBSTRING(@String,1,@SplitLength))

         SET @String=SUBSTRING(@String,@SplitLength+1,len(@String)-@SplitLength) 

        End     

    End

RETURN
END

我与表变量连接,该变量包含具有要拆分的字符串的列

    DECLARE @LeftSuper TABLE
(
KeyTerm VARCHAR(MAX),
Data VARCHAR(MAX) ,

)

查询如下生成错误(无法调用表上的方法)

 select KeyTerm ,D.Splited from @LeftSuper
 outer apply [Split](@LeftSuper.Data,300) as D

注意:代码适用于db。中的Real Table。

1 个答案:

答案 0 :(得分:5)

为表变量引入别名,并在表达式中使用它:

select KeyTerm ,D.Splited from @LeftSuper ls
 outer apply [Split](ls.Data,300) as D

这实际上相当普遍 - 因为表在查询中可能会出现多次,每次在查询中遇到@LeftSuper时,都会将其视为对表的 new 引用 - 不是已经添加的引用 - 别名允许您引用。