繁体   English   中英

Report Builder 3.0 - 如何使用大型数据集运行此报告?

[英]Report Builder 3.0 - How can I run this report with a large data set?

我是使用大量数据开发报告的新手,所以我正在寻找一些关于我遇到的问题的建议。

我正在开发一个包含 6 个参数的 SSRS 报告。 每个参数都有自己的数据集,为参数指定一个不同的值列表。

用户可以为每个参数选择任意数量的值,但 1(日期)除外。

查询看起来像;

SELECT [CURR].[PERIOD]
,[CURR].[PERIOD_MTD]
,[CURR].[CATEGORY1]
,[CURR].[CATEGORY2]
,[CURR].[CATEGORY3]
,[CURR].[CATEGORY4]
,[CURR].[CATEGORY5]
,[CURR].[CALCULATION1_ITD]
,[CURR].[CALCULATION2_ITD]
,[CURR].[CALCULATION3_ITD]
,[CURR].[CALCULATION4_ITD]
,[CURR].[CALCULATION1_MTD]
,[CURR].[CALCULATION2_MTD]
,[CURR].[CALCULATION3_MTD]
,[CURR].[CALCULATION4_MTD]
FROM [BIG_TABLE] [CURR] LEFT OUTER JOIN
[BIG_TABLE] [PREV M]
    ON [CURR].[PERIOD_MTD] = [PREV M].[PERIOD]
    AND [CURR].[CATEGORY1] = [PREV M].[CATEGORY1]
    AND [CURR].[CATEGORY2] = [PREV M].[CATEGORY2]
    AND [CURR].[CATEGORY3] = [PREV M].[CATEGORY3]
    AND [CURR].[CATEGORY4] = [PREV M].[CATEGORY4]
    AND [CURR].[CATEGORY5] = [PREV M].[CATEGORY5]
WHERE [CURR].[PERIOD] = @YYYYMM
AND [CURR].[CATEGORY1] IN (@PARAMETER1)
AND [CURR].[CATEGORY2] IN (@PARAMETER2)
AND [CURR].[CATEGORY3] IN (@PARAMETER3)
AND [CURR].[CATEGORY4] IN (@PARAMETER4)
AND [CURR].[CATEGORY5] IN (@PARAMETER5)

这是我遇到的问题; 1 个参数有一个包含 5,500 多个值的不同列表,用户可以从中进行选择。 选择所有值后,我注意到参数字段不像其他值那样填充(下图)。

参数图

报告运行时,我收到以下错误:

错误信息

此消息非常含糊,但我将其隔离为报告将在此参数中使用较少值运行的事实,但不是全部。

我不确定还能尝试什么。 我认为这可能是通过主数据集获取大量数据的问题。

额外的信息:

通过到 SharePoint 的共享连接访问数据源

为此报告查询的表没有索引。 我想知道这是否重要,因为该表大约有 26.5mill 行。

我建议你的方法是错误的。

如果您向用户展示一个包含 5000 多个项目的列表以供选择,我猜他们要么会选择其中的一小部分,要么想要 select 所有人,他们不太可能会坐在那里并从中选择 100 个项目一个列表。

如果是这种情况,那么我建议在列表中附加一个“ALL”选项( UNION到您的原始列表中),然后像这样修改查询......

WHERE [CURR].[PERIOD] = @YYYYMM
AND (@PARAMETER1 = 'ALL' OR [CURR].[CATEGORY1] IN (@PARAMETER1))
...
...

您可能还想阅读这些以前的 SO 问题和 MS 文章。

Sql 服务器中的“IN”子句限制

https://docs.microsoft.com/en-us/sql/t-sql/language-elements/in-transact-sql?view=sql-server-ver15

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM