我正在尝试创建sum()表达式,它将总结行并将结果放入“TPM中的总服务器”列中。看起来我无法提供合适的表达式。在设计模式中SSRS矩阵报表总和表达式
SSRS矩阵报告如下所示:
[TPM_scan_type]表达式可以具有2个值: “TPM Succesfull扫描” 或 “TPM失败扫描”
=Switch(Fields!ScanStatus.Value = "OK","TPM Succesfull Scan",Fields!ScanStatus.Value = "FAILED!","TPM Failed Scan")
[scan_count]表达式只是每个“Primary SA”的聚合值
=Switch(Fields!ScanStatus.Value="FAILED!",Count(Fields!ScanStatus.Value),Fields!ScanStatus.Value="OK", CountDistinct(Fields!ServerName.Value))
结果:
数据样本:
USE tempdb;
GO
IF OBJECT_ID('dbo.TPM_test') IS NOT NULL
DROP TABLE dbo.TPM_test;
GO
CREATE TABLE dbo.TPM_test
(
ServerName varchar(30) NOT NULL,
ScanStatus varchar(10) NOT NULL,
Primary_SA varchar(30) NOT NULL,
HotfixID int
);
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('LDNSQLF700', 'OK', 'SA1', 157848);
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('LDNSQLF700', 'OK', 'SA1', 976832);
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('LDNSQLF700', 'OK', 'SA1', 234354);
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('NYSQL502', 'FAILED!', 'SA1', '');
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('PSQL1011', 'FAILED!', 'SA1', '');
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('NTQDF002', 'OK', 'SA1', 878641);
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('AUSSQL140', 'OK', 'SA2', 537990);
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('AUSSQL140', 'OK', 'SA2', 1349605);
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('JAP543X2', 'FAILED!', 'SA2', '');
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('EU456CLX', 'FAILED!', 'SA2', '');
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('EUCTX654', 'OK', 'SA2', 5637965);
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('EUCTX654', 'OK', 'SA2', 6464367) ;
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('EUCTX654', 'OK', 'SA2', 1323123) ;
INSERT INTO dbo.TPM_test(ServerName, ScanStatus, Primary_SA, HotfixID)
VALUES('EUCTX654', 'OK', 'SA2', 1004326) ;
GO
如果我的示例对我的示例没有用处,可以添加一个半行数据集示例数据集吗?另外,你能解释为什么你使用'Count(Fields!ScanStatus.Value)'失败,'CountDistinct(Fields!ServerName.Value)'成功? –
Hi @ Ian。感谢你及时的答复。 CountRows()可以部分完成这项工作,但是我拥有的数据集迫使我使用开关。这完全是因为Fields!ScanStatus可以为服务器提供两个值:“失败!”或“确定”。但“失败!”是独一无二的价值(针对每台机器),与“OK!”相反对于每个服务器重复几次(因为扫描返回服务器上缺失的修补程序)。所以我需要区分“OK”值来获得扫描成功的服务器的数量。 – Mario
我把数据样本放在上面的SQL表中。关于您之前问过的问题:“您能解释为什么您使用... CountDistinct(Fields!ServerName.Value)取得成功吗?”失败有独特的价值,所以我只是通过“Count(Fields!ScanStatus.Value)”来统计它们。我不能通过“OK”状态进行聚合,因为我只在每行中获得一个,所以我使用serverName来完成这项工作。 – Mario