![](/img/trans.png)
[英]How can I modify a MySQL query to work in 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 文章。
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.