函数返回空集

时间:2013-08-26 21:18:21

标签: sql sql-server-2008 table-functions

我已在SQL 2008中成功创建了一个函数:

ALTER FUNCTION [dbo].Func_raw_data_xref (@ColName AS NVARCHAR(255)) 
RETURNS @VVSrcCDs TABLE ( 
  VV_SRC_CD      NVARCHAR(255) NULL, 
  VV_CD          NVARCHAR(255) NULL, 
  VV_SRC_CD_DESC NVARCHAR(255) NULL, 
  VV_DSC         NVARCHAR(255) NULL ) 
AS 
  BEGIN 
      DECLARE @vv_SRC_CD      NVARCHAR(255), 
              @vv_CD          NVARCHAR(255), 
              @vv_SRC_CD_DESC NVARCHAR(255), 
              @vv_DSC         NVARCHAR(255); 

      SELECT @vv_SRC_CD = A.VV_SRC_CD, 
             @vv_CD = A.VV_CD, 
             @vv_SRC_CD_DESC = A.VV_SRC_CD_DESC, 
             @vv_DSC = A.VV_DSC 
      FROM   DBO.VALUES A 
             JOIN VVLOOKUP B 
               ON A.VV_SRC_CD = b.VV_SRC_CD 
      WHERE  B.[CLIENT COLUMN NAME] = @ColName 

      RETURN; 
  END 

问题出在我调用函数时:

SELECT * 
FROM   DBO.Func_raw_data_xref('_CD'); 

我没有结果。我得到的是函数中引用的列,但没有数据。如果我将select语句复制出函数并使用@ColName的有效参数运行它,我会得到结果。

1 个答案:

答案 0 :(得分:2)

您不必将select的结果分配给局部变量。你要做的是将SELECT的结果INSERT到你声明为返回值的表变量中:

而不是

  DECLARE 
     @vv_SRC_CD NVARCHAR(255),
     @vv_CD NVARCHAR(255),
     @vv_SRC_CD_DESC NVARCHAR(255),
     @vv_DSC NVARCHAR(255);

    SELECT 
        @vv_SRC_CD = A.vv_SRC_CD,
        @vv_CD = A.vv_CD, 
        @vv_SRC_CD_DESC = A.vv_SRC_CD_DESC,
        @vv_DSC = A.vv_DSC
    FROM DBO.values A
    JOIN VVLookup B
    ON A.vv_SRC_CD = b.vv_SRC_CD
    WHERE B.[Client Column Name] = @ColName

尝试

INSERT INTO @VVSrcCDs
SELECT 
            A.vv_SRC_CD,
            A.vv_CD, 
            A.vv_SRC_CD_DESC,
            A.vv_DSC
        FROM DBO.values A
        JOIN VVLookup B
        ON A.vv_SRC_CD = b.vv_SRC_CD
        WHERE B.[Client Column Name] = @ColName