sql-server-2005 – 为什么SQL查询中的NULL聚合警告会导致SSIS包
SSIS包失败,并显示如下错误消息:
在调查中,我们发现聚合或其他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包失败是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的更多信息. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |