Microsoft 在一个可下载文件中分发 Microsoft SQL Server 2012 修复程序。 由于修补程序是累积的,因此每个新版本都包含以前的 SQL Server 2012 更新版本附带的所有修补程序和所有安全更新。
症状
请考虑以下情况:
-
在具有许多 Cpu 的服务器上安装 Microsoft SQL Server 2012。 例如,服务器上的 CPU 具有64或128内核,并且包含 NUMA 配置。
-
服务器的内存量很大。 例如,服务器具有256千兆字节(GB)或 1 tb 的内存。
-
在 Microsoft SQL Server 2012 中执行查询。 查询执行计划包含一个适用于多行的排序运算符。
在此方案中,将在 SQL Server 错误日志文件中记录类似于以下内容的错误消息:
进程<阻止列表>似乎不会在计划程序<ID上生成>
原因
出现此问题的原因是排序运算符在内存分配的内部 SQL Server 列表中遍历了许多存储桶,以查找缓冲池中的下一个可用内存。当服务器具有较大的内存时,缓冲区池中的内存分配的内部 SQL Server 列表也增大到较大大小。 因此,排序运算符在内存分配的内部 SQL Server 列表中遍历许多存储桶,以查找缓冲区池中的下一个可用内存。 此行为不会经常对计划程序产生任何影响。 因此,将频繁报告 "未生成计划程序" 错误。
解决方案
累积更新信息
SQL Server 2012 Service Pack 1 的累积更新包1
此问题的修补程序首次在累积更新1中发布。有关如何获取此累积更新包的 SQL Server 2012 Service Pack 1 的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2765331 SQL Server 2012 Service Pack 1 的累积更新包1注意 由于这些版本是累积的,因此每个新的修复版本都包含以前的 SQL Server 2012 修复版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2772858 在发布 SQL Server 2012 Service Pack 1 之后发布的 SQL Server 2012 版本
SQL Server 2012
此问题的修补程序首次在累积更新4中发布。有关如何为 SQL Server 2012 获取此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2758687 SQL Server 2012 累积更新程序包4注意 由于这些版本是累积的,因此每个新的修复版本都包含以前的 SQL Server 2012 修复版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2692828 在 SQL Server 2012 发布后发布的 SQL Server 2012 版本
状态
Microsoft 已确认这是在“适用范围”部分中列出的 Microsoft 产品存在的问题。