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

前端之家收集整理的这篇文章主要介绍了sql-server-2005 – 为什么SQL查询中的NULL聚合警告会导致SSIS包失败?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
SSIS包失败,并显示如下错误消息:

Code: 0xC0202009
Source: DFT Populate ImageSummary OLE_SRC ProductImage [1]
Description: SSIS Error Code DTS_E_OLEDBERROR. An OLE DB error has occurred. Error code: 0x80004005.
An OLE DB record is available. Source: “Microsoft sql Native Client” Hresult: 0x00040EDA Description: “Warning: Null value is eliminated by an aggregate or other SET operation.”.

在调查中,我们发现聚合或其他SET操作消除了警告:空值的消息.由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,spi2.Size 
        ORDER BY spi.ProductID,spi2.Size
        )a
    )b 
where ranker = 1 
Order by ProductID,ImageTypeID

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

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

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

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

>为什么来自sql的警告会冒泡到SSIS包并导致
SSIS包失败了吗?
>如果我们在所有其他开发和UAT环境中运行相同的包
使用相同的数据集,它工作正常.我们可以看到警告
然而,在sql Server Management Studio显示却没有
导致SSIS失败.但是我们生产中的SSIS包
环境失败.我们没有理解逻辑?在那儿
任何警告门槛?

解决方法

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

警告:聚合或其他SET操作消除了空值

Link to the bug report on Connect website.

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

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.

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

SET ANSI_WARNINGS OFF;

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

猜你在找的MsSQL相关文章