Microsoft 将 Microsoft SQL Server 2008 R2 SP1 修复分发为一个可下载文件。 由于修补程序是累积的,因此每个新版本都包含以前的 SQL Server 2008 R2 SP1 修复版本附带的所有修补程序和所有安全修补程序。
症状
请考虑以下方案。 在 Microsoft SQL Server 2008 R2 中运行使用嵌套的 交叉结合 函数的 MDX 查询。 嵌套 交叉结合 函数引用某些交错层次结构。 在这种情况下,查询运行速度非常慢,SQL Server 2008 R2 可能会停止响应。 例如,你可以运行类似于以下内容的 MDX 查询:
CrossJoin (CrossJoin (CrossJoin (CrossJoin([Dimension1 Hierarchy], [Dimension1 Hierarchy])), [Dimension1 Hierarchy]), [Dimension2 Hierarchy]), [Dimension1 Hierarchy])注意
-
在交错层次结构中,嵌套的 交叉结合 函数引用不同的维度层次结构。
-
SQL Server 2008 中不会出现此问题。
原因
出现此问题的原因是对来自相同维度的组层次结构所需的内存增加了指数,最终使用。
解决方案
累积更新信息
SQL Server 2008 R2 Service Pack 2
此问题的修补程序首次在累积更新3中发布。有关如何为 SQL Server 2008 R2 Service Pack 2 获取此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2754552 SQL Server 2008 R2 Service Pack 2 的累积更新包3 注意 由于这些版本是累积的,因此每个新的修复版本都包含了以前的 SQL Server 2008 R2 Service Pack 2 修复版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2730301 发布 SQL Server 2008 R2 Service Pack 2 后发布的 SQL Server 2008 R2 版本
SQL Server 2008 R2 SP1
此问题的修补程序首次发布,即累积更新8。有关如何为 SQL Server 2008 R2 获取此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2723743 SQL Server 2008 R2 Service Pack 1 的累积更新程序包8注意 由于这些版本是累积的,因此每个新的修复版本都包含了以前的 SQL Server 2008 R2 修补程序版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2567616 在发布 SQL Server 2008 R2 Service Pack 1 之后发布的 SQL Server 2008 R2 版本
状态
Microsoft 已确认这是在“适用范围”部分中列出的 Microsoft 产品存在的问题。
解决方法
若要解决此问题,请将查询更改为将第二个维度层次结构放置在外部 交叉结合 函数中。 例如,将查询重写为如下所示:
CrossJoin(CrossJoin(CrossJoin (CrossJoin([Dimension1 Hierarchy], [Dimension1 Hierarchy])),[Dimension1 Hierarchy]), [Dimension1 Hierarchy]), [Dimension2 Hierarchy])