为什么SQL查询中的NULL聚合警告会导致SSIS包失败?

Par*_*kar 9 ssis sql-server-2005

SSIS包失败,出现如下错误消息:

代码:0xC0202009源:DFT填充ImageSummary OLE_SRC ProductImage [1]描述:SSIS错误代码DTS_E_OLEDBERROR.发生OLE DB错误.错误代码:0x80004005.OLE DB记录可用.来源:"Microsoft SQL Native Client"Hresult:0x00040EDA描述:"警告:聚合或其他SET操作消除了空值."

经过调查,我们发现Warning: Null value is eliminated by an aggregate or other SET operation.SQL Server(2005)查询返回的消息是SSIS包作为DFT中的源运行以插入到目标表中.

Select ProductID ,ImageTypeID ,DistinctImageCount ,ImageSize 
from 
    (select a.ProductID ,a.ImageTypeID ,a.DistinctImageCount ,a.ImageSize ,RANK() OVER (PARTITION BY a.ProductID, a.ImageTypeID ORDER BY a.ImageSize) As Ranker 
    from 
        (SELECT TOP 100 Percent spi.ProductID ,sit.ImageTypeID ,CAST(COUNT(DISTINCT spi2.ImageTypeID) as bit) DistinctImageCount ,CAST(spi2.Size as varchar(50)) as ImageSize 
        FROM Stage.ProductImage spi CROSS JOIN Reference.ImageType sit LEFT JOIN Stage.ProductImage spi2 ON spi.ProductID = spi2.ProductID AND sit.ImageTypeID = spi2.ImageTypeID 
        GROUP BY spi.ProductID, sit.ImageTypeID,spi2.Size 
        ORDER BY spi.ProductID, sit.ImageTypeID,spi2.Size
        )a
    )b 
where ranker = 1 
Order by ProductID,ImageTypeID
Run Code Online (Sandbox Code Playgroud)

我们通过修改查询来消除来自SQL Server的警告消息,从而解决了这个问题:

CAST(COUNT(DISTINCT spi2.ImageTypeID)as bit) DistinctImageCount

CAST(SUM(DISTINCT ISNULL(spi2.ImageTypeID,0)) as bit) DistinctImageCount.

但是我们几个问题如下,我们无法找到解释并希望在此论坛上得到答案:

  1. 为什么来自SQL的警告会冒泡到SSIS包并导致SSIS包失败?

  2. 如果我们在具有相同数据集的所有其他dev和UAT环境中运行相同的包,则它可以正常工作.我们可以在SQL Server Management Studio中看到警告,但不会导致SSIS失败.但是,生产环境中的SSIS包失败.我们没有理解逻辑?是否有任何警告门槛?

小智 9

由于以下警告消息导致的SSIS包失败是Microsoft Connect网站上许多人报告的已知错误.

Warning: Null value is eliminated by an aggregate or other SET operation

链接到Connect网站上的错误报告.

微软团队关于该问题的最新更新:

This problem was resolved in SQL Server 2012 RTM (11.00.2100.60 or later).
There is no hotfix available for SQL Server 2005/2008/2008R2.
Run Code Online (Sandbox Code Playgroud)

我不知道问题的原因,微软团队也将此错误视为不可重现.Connect网站上列出的解决方法之一是在查询之前添加以下语句.请确保在结尾处包含分号.

SET ANSI_WARNINGS OFF;
Run Code Online (Sandbox Code Playgroud)

阅读MSDN上有关ANSI_WARNINGS的更多信息.