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 产品存在的问题。

Need more help?

Expand your skills
Explore Training
Get new features first
Join Microsoft Insiders

Was this information helpful?

How satisfied are you with the translation quality?
What affected your experience?

Thank you for your feedback!

×