1

我收到了一份相当复杂的报告并要求对其进行更新,以便用户可以输入多个参数的值(其中一些然后在多值参数中显示选择),以便生成所有计算机名称的列表,其中包含一个或更具体的软件包安装在他们身上。

主查询的“简化”版本(如下所示)有效,但不幸的是,该报告有时会为同一台计算机上的同一软件包列出几乎重复的行;一个有安装日期,另一个没有安装。也有没有安装日期的记录,但没有对应的安装日期记录。

我可以通过在 WHERE 子句中添加“AND arp.InstallationDate0 IS NOT NULL”来消除没有安装日期的行,但是如何更改查询,以便如果存在重复记录,则只显示具有安装日期的记录,然而如果只存在一条没有安装的记录,是否显示该记录?

谢谢你尽你所能的帮助。

SELECT DISTINCT sys.Name0 , arp.DisplayName0 , arp.Version0 , arp.InstallDate0 

FROM v_R_System sys 

INNER JOIN (SELECT * FROM v_GS_ADD_REMOVE_PROGRAMS UNION SELECT * 
  FROM v_GS_ADD_REMOVE_PROGRAMS_64) arp ON sys.ResourceID = arp.ResourceID 

INNER JOIN v_FullCollectionMembership fcm ON sys.ResourceID = fcm.ResourceID 

WHERE arp.DisplayName0 IN (@productname) AND COALESCE (arp.Version0, '') LIKE @version  
  AND fcm.CollectionID IN (@selectcollection) 

ORDER BY sys.Name0
4

1 回答 1

0

将安装日期包装在聚合函数和 isnull 函数中。

max(isnull(arp.InstallDate0, '31-Dec-1900')) as installdate0

确保也包括该group by子句。

于 2012-12-16T02:24:03.433 回答