0

我有一个查询,它根据所需的日期范围(参数)为我提供项目的每日状态。这种状态会有所不同并且可以重复。例如,它可以按时间顺序为:操作、维修、检查、操作、检查。如您所见,操作和检查代表两次,但时间不同。虽然这是真的,但我似乎无法在范围条形图中以图形方式表示这一点,因为它只会显示每个状态的一个实例(如图所示)。图片指示应在何处显示剩余状态。

范围条形图错误

我正在使用的数据集如下:

范围条形图错误数据

如您所见,图表应按以下顺序表示 4 个状态:检查、操作、维修、操作,但不显示第二个操作状态。

谁能帮助我克服这个特殊的障碍,或者这不可能吗?

4

1 回答 1

0

这应该为您指明正确的方向......这就是我可能会采用的方法。

您需要向数据集添加额外的列。我将您的数据集复制到表变量中,然后使用以下内容获取附加列

-- this just replicates your data..    
DECLARE @t TABLE(StatusDate DATE, StatType varchar(20), statStart DateTime, statEnd DateTime, StatusDays int)

    INSERT INTO @t VALUES
    ('2017-02-16', 'Inspection', '2017-01-30 12:49:14', '2017-02-21 12:49:14', 22),
    ...
    ...
    ('2017-03-14', 'Operational', '2017-03-01 11:49:11', '2017-04-19 15:19:48', 49)

-- the important bit    
    SELECT 
        *
        , DENSE_RANK() OVER(ORDER BY statStart) as Sort
     FROM @t

这给了我们以下输出。

在此处输入图像描述

我们可以使用 SSRS 中的这个额外字段对数据进行正确分组和排序。

在此处输入图像描述

然后,我对图表系列颜色属性使用了以下表达式,以确保颜色与 statType 一致

=SWITCH(
    Fields!StatType.Value = "Inspection", "Tan",
    Fields!StatType.Value = "Operational", "Green",
    Fields!StatType.Value = "Repair", "Red",
    True, "Blue"
    )

(如果我们缺少一种类型,蓝线就在那里,它会在图表上显示为蓝色。)

这给了我们.. 在此处输入图像描述

希望这会给你足够的继续。

于 2018-01-16T16:25:08.057 回答