[英]SCCM Hardware Reports [if there are multiple values (for all columns) then combine them together] How?
[英]Modifying SCCM reports
SCCM 报告中提供了一条 SQL 语句,用于获取具有给定网卡的计算机列表。
SELECT SYS.Name0, Netcard.Description0,Netcard.MACAddress0, Netcard.Manufacturer0
FROM fn_rbac_R_System(@UserSIDs) SYS, fn_rbac_GS_NETWORK_ADAPTER(@UserSIDs) Netcard
WHERE SYS.ResourceID = Netcard.ResourceID AND Netcard.Description0 LIKE @variable
ORDER BY SYS.Name0
我想将计算机型号添加到此报告中。 我应该如何修改sql语句?
谢谢
*编辑@SQLChao 有什么我应该查看数据集的吗?
这是一个冗长的 SQL 查询,为 sccm 中的一组计算机提取了许多详细信息。
这将是我想添加到上面的查询中的内容,但是这个查询似乎使用了更复杂的语法。
v_GS_COMPUTER_SYSTEM_Alias.Model0 AS [Model]
完整查询在这里。
v_GS_LOGICAL_DISK_Alias.ResourceID )
where v_GS_LOGICAL_DISK_Alias.ResourceID =v_R_System_Valid_Alias.ResourceID and v_FullCollectionMembership_Alias.CollectionID = @CollectionID) As [Free Disk Space (MB)]
from fn_rbac_R_System_Valid(@UserSIDs) v_R_System_Valid_Alias
inner join v_GS_OPERATING_SYSTEM v_GS_OPERATING_SYSTEM_Alias on (v_GS_OPERATING_SYSTEM_Alias.ResourceID = v_R_System_Valid_Alias.ResourceID)
left join v_GS_SYSTEM_ENCLOSURE_UNIQUE v_GS_SYSTEM_ENCLOSURE_UNIQUE_Alias on (v_GS_SYSTEM_ENCLOSURE_UNIQUE_Alias.ResourceID = v_R_System_Valid_Alias.ResourceID)
LEFT join v_GS_COMPUTER_SYSTEM v_GS_COMPUTER_SYSTEM_Alias on (v_GS_COMPUTER_SYSTEM_Alias.ResourceID = v_R_System_Valid_Alias.ResourceID)
LEFT join v_GS_X86_PC_MEMORY v_GS_X86_PC_MEMORY_Alias on (v_GS_X86_PC_MEMORY_Alias.ResourceID = v_R_System_Valid_Alias.ResourceID)
LEFT join v_GS_PROCESSOR v_GS_PROCESSOR_Alias on (v_GS_PROCESSOR_Alias.ResourceID = v_R_System_Valid_Alias.ResourceID)
inner join v_FullCollectionMembership v_FullCollectionMembership_Alias on (v_FullCollectionMembership_Alias.ResourceID = v_R_System_Valid_Alias.ResourceID)
left join fn_rbac_Site(@UserSIDs) v_Site_Alias on (v_FullCollectionMembership_Alias.SiteCode = v_Site_Alias.SiteCode)
LEFT join v_GS_LOGICAL_DISK v_GS_LOGICAL_DISK_Alias on (v_GS_LOGICAL_DISK_Alias.ResourceID = v_R_System_Valid_Alias.ResourceID) and v_GS_LOGICAL_DISK_Alias.DeviceID0=SUBSTRING(v_GS_OPERATING_SYSTEM_Alias.WindowsDirectory0,1,2)
left join v_GS_SYSTEM_CONSOLE_USAGE_MAXGROUP v_GS_SYSTEM_CONSOLE_USAGE_MAXGROUP_Alias on (v_GS_SYSTEM_CONSOLE_USAGE_MAXGROUP_Alias.ResourceID = v_R_System_Valid_Alias.ResourceID)
Where v_FullCollectionMembership_Alias.CollectionID = @CollectionID
Order by v_R_System_Valid_Alias.Netbios_Name0
它应该与类似的东西一起工作
SELECT
SYS.Name0,
SYS.Model0,
Netcard.Description0,
Netcard.MACAddress0,
Netcard.Manufacturer0
FROM
(
SELECT
S.ResourceID,
S.Name0,
C.Model0
FROM
fn_rbac_R_System(@UserSIDs) S
LEFT JOIN
V_GS_COMPUTER_SYSTEM C
ON
S.ResourceID = C.ResourceID
) SYS,
fn_rbac_GS_NETWORK_ADAPTER(@UserSIDs) Netcard
WHERE
SYS.ResourceID = Netcard.ResourceID
AND
Netcard.Description0 LIKE @variable
ORDER BY
SYS.Name0
也可以在整个旧查询之后离开连接:
SELECT
t1.*,
c.Model0
FROM
(
SELECT
SYS.ResourceID,
SYS.Name0,
Netcard.Description0,
Netcard.MACAddress0,
Netcard.Manufacturer0
FROM
fn_rbac_R_System(@UserSIDs) SYS,
fn_rbac_GS_NETWORK_ADAPTER(@UserSIDs) Netcard
WHERE
SYS.ResourceID = Netcard.ResourceID
AND
Netcard.Description0 LIKE @variable
) t1
LEFT JOIN
V_GS_COMPUTER_SYSTEM c
ON
t1.ResourceID = c.ResourceID
ORDER BY t1.Name0
我不是 SQL 专家,不知道在这种情况下哪个更可取,但对于普通的 sccm db 来说,两者都应该是可以接受的。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.