reporting-services - 运行值 CountDistinct 和逻辑表达式?
问题描述
我有这样的原始数据。
我需要用它创建两个报告,这是第一个报告:
运行值可以用这个表达式来实现
RunningValue(Fields!City.Value+Fields!Month.Value,CountDistinct,"Region")
我需要的第二份报告是这样的:
我可以做些什么来为运行值添加逻辑,这样它就可以避免 Sum(Amount) 为零的行编号?
解决方案
我不确定您是否可以使用 RunningValue 执行此操作,其他人可能知道一种方法。
我所做的是将逻辑移到查询中。
我复制了一些数据以匹配您的最终报告编号(您的示例数据与示例报告输出不匹配)。
这是我使用的示例数据。
DECLARE @t TABLE(Region varchar(10), City varchar(10), MonthID int, Amount int)
INSERT INTO @t VALUES
('Asia', 'Tokyo', 4, 1000),
('Asia', 'Tokyo', 4, 500),
('Asia', 'Tokyo', 5, 2000),
('Asia', 'Tokyo', 5, -2000),
('Asia', 'Tokyo', 6, 1000),
('Asia', 'Tokyo', 6, -500),
('Asia', 'Bangkok', 4, 500),
('Asia', 'Bangkok', 4, 500),
('Asia', 'Bangkok', 5, 3000),
('Asia', 'Bangkok', 5, -500),
('Asia', 'Bangkok', 6, -750),
('Asia', 'Bangkok', 6, 750)
SELECT
*
, ROW_NUMBER() OVER(PARTITION BY Region, City ORDER BY MonthID) as RowN1
, ROW_NUMBER() OVER(PARTITION BY (CASE Amount WHEN 0 THEN 0 ELSE 1 END), Region, City ORDER BY MonthID) as RowN2
FROM
(
SELECT
Region, City, MonthID
, SUM(Amount) AS Amount
FROM @t
GROUP BY Region, City, MonthID
) x
ORDER BY Region, City DESC, MonthID
我使用 ROW_NUMBER 函数为两个报告分配行号。
第一个“RowN1”是城市内的简单行号
第二个“RowN2”做同样的事情,但它对任何零值进行分区,因此它们与其他数据不在同一个分区中。
现在您可以使用一个简单的表格在您的第一个报告中使用 RowN1 显示结果
在您的第二份报告中,将 RowN2 与表达式一起使用
=IIF(Fields!Amount.Value=0, Nothing, Fields!RowN2.Value)
如果金额为零,这只会强制显示空白。
我这样做并得到了以下结果。
注意:我在数据中使用了月份数字,只是为了方便排序,在报告中我用来=MonthName(Fields!MonthID.Value)
显示实际名称。
推荐阅读
- node.js - 员工层次结构的递归函数(nodejs)
- javascript - Promise 函数中的 Promise:无法将数据推送到数组中
- javascript - JS 异步函数停止页面加载
- python - 删除字符串中每个句子中特定符号后的单词
- python - Odoo V10 - 计算字段
- node.js - 无法从 react-script 卸载 webpack
- ios - iOS 框架关系
- c - C 编程 - 从文件中读取数据并将其存储在链表中
- javascript - 带/不带引号的 Javascript 对象属性
- java - 在 spring-boot 中有多个 WebSecurityConfigurerAdapter 的问题