我收到了一份相当复杂的报告并要求对其进行更新,以便用户可以输入多个参数的值(其中一些然后在多值参数中显示选择),以便生成所有计算机名称的列表,其中包含一个或更具体的软件包安装在他们身上。
主查询的“简化”版本(如下所示)有效,但不幸的是,该报告有时会为同一台计算机上的同一软件包列出几乎重复的行;一个有安装日期,另一个没有安装。也有没有安装日期的记录,但没有对应的安装日期记录。
我可以通过在 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