在 SQL Server Management Studio 中执行查询时出现 OutOfMemoryException 错误 (SSMS)

本文可帮助你解决使用 SQL Server Management Studio (SSMS) 运行返回大量数据的 SQL 查询时发生的问题。

原始产品版本:SQL Server
原始 KB 数: 2874903

现象

使用 SSMS 运行返回大量数据的 SQL 查询时,会收到如下所示的错误消息:

执行批处理时出错。 错误消息为:抛出了“System.OutOfMemoryException”类型的异常

原因

出现此问题的原因是 SSMS 的内存不足,无法为大型结果分配内存。 SSMS 是一个 32 位进程。 因此,它限制为 2 GB 的用户模式虚拟内存。 SSMS 对结果窗口中每个数据库字段可以显示多少文本施加人工限制。 此限制在网格模式下为 64 KB,在文本模式下为 8 KB。 如果结果集太大,显示查询结果所需的内存可能会超过 SSMS 进程的 2 GB 限制。 因此,大型结果集可能会导致“症状部分中提到的错误。

解决方法

若要解决此问题,请尝试以下方法之一。

方法 1:将结果输出为文本

配置查询窗口以将查询结果输出为文本。 文本输出使用的内存小于网格,并且可能足以显示查询结果。 若要进行此更改,请执行以下步骤:

  1. 右键单击查询窗口。
  2. 选择 结果
  3. 选择结果到文本

方法 2:将结果输出到文件

配置查询窗口以将查询结果输出到文件。 文件输出使用最少的内存量。 这会保留更多内存来存储结果集。 若要进行此更改,请执行以下步骤:

  1. 右键单击查询窗口。
  2. 选择结果
  3. 选择结果到文件
  4. 运行查询,然后选择保存结果文件的位置。

方法 3:使用 sqlcmd

使用 sqlcmd 实用工具 而不是 SSMS 来运行 SQL 查询。 此方法允许在没有 SSMS UI 所需的资源的情况下运行查询。 此外,可以使用 64 位版本的 Sqlcmd.exe 来避免影响 32 位 SSMS 进程的内存限制。