在虚拟表中使用Sql Function错误

时间:2018-07-02 13:32:04

标签: sql sql-server

        CREATE FUNCTION dbo.Get_LogoFaturaIskonto (
        @InvoiceRef     int = 0,
        @ParentlnRef    int = 0,
        @Rownumber      int = 0
    )
    RETURNS decimal(18,2)
    AS
    BEGIN
        DECLARE @VALUE decimal(18,2)
        WITH NEWTABLE AS 
        (SELECT ROW_NUMBER() OVER(ORDER BY LOGICALREF ASC) AS ROWNUMBER#
      ,DISCPER,LOGICALREF,INVOICEREF,PARENTLNREF FROM dbo.LG_002_01_STLINE 
    WHERE 
       INVOICEREF = @InvoiceRef AND PARENTLNREF = @ParentlnRef AND LINETYPE = 2)
        SELECT @VALUE = (SELECT * FROM NEWTABLE WHERE ROWNUMBER = @Rownumber)
        RETURN ISNULL(@VALUE,0)
    END

Errrr消息

第319行15级状态1程序Get_LogoFaturaIskonto,第11行 关键字“ with”附近的语法不正确。如果此语句是公用表表达式,xmlnamespaces子句或更改跟踪上下文子句,则前一条语句必须以分号终止。

1 个答案:

答案 0 :(得分:0)

至少在缺少分号时:

CREATE FUNCTION dbo.Get_LogoFaturaIskonto (
    @InvoiceRef     int = 0,
    @ParentlnRef    int = 0,
    @Rownumber      int = 0
)
RETURNS decimal(18,2)
AS
BEGIN
    DECLARE @VALUE decimal(18,2);

    WITH NEWTABLE AS 
    (SELECT ROW_NUMBER() OVER(ORDER BY LOGICALREF ASC) AS ROWNUMBER#
  ,DISCPER,LOGICALREF,INVOICEREF,PARENTLNREF FROM dbo.LG_002_01_STLINE 
WHERE 
   INVOICEREF = @InvoiceRef AND PARENTLNREF = @ParentlnRef AND LINETYPE = 2)
    SELECT @VALUE = (SELECT * FROM NEWTABLE WHERE ROWNUMBER = @Rownumber)
    RETURN ISNULL(@VALUE,0)
END