SQL Server出现System.OutOfMemoryException异常的解决方法
今天在用SQL Server 2008执行一个SQL脚本文件时,老是出现引发类型为“System.OutOfMemoryException”的异常错误,脚本明明是从SQL Server 2008导出的,应该不会出错,研究了好久问题才得以解决。 出现这个错误的主要原因是由于SQL脚本文件太大,估计超过了100M了,解决方法就是把脚本文件分成几个脚本文件,分别去执行即可。
原因:因为计算机没有足够的内存来完成请求的操作,则会出现此问题。 在 SQL Server 2000 Reporting Services 的限制会导致内存绑定的处理报告的某些部分。例如,查询结果处理和对象模型呈现受限于内存。 计算机没有足够的内存来完成请求的操作在一个或多个下列条件都为真: 1.一个报告是太大或太复杂。 处理报表,则分两个阶段。两个阶段是执行和呈现。在执行阶段期间或在呈现阶段,会出现此问题。 如果在执行阶段中,会出现此问题,此问题很可能是因为太多的内存消耗在查询结果中返回的数据。此外,下列因素会影响内存消耗,在执行阶段: 1.分组 如果在呈现阶段中会发生此问题,原因被与该报表显示何种信息以及报表显示信息的方式。 1.数量和类型的控件 解决方案:若要解决此问题,请使用下列方法之一。 方法 1向计算机中添加足够的物理内存。 注意如果您超过 2 千兆字节 (GB) 的内存可以启用该 / 3gb 切换在 Boot.ini 文件中为更好的性能。 有关如何在 SQL Server 中使用了 / 3gb 开关的详细信息单击下面的文章编号,以查看 Microsoft 知识库中相应的文章: 方法 2将报告计划安排为在内存限制时较低的非高峰时段运行。 方法 3调整所在进行相应设置。 注意:呈现时通过报告服务 Web 服务的报告,该报告服务 Web 服务从 Machine.config 文件中获得所在。但是,计划的报告呈现由报表服务器的 Windows 服务。报表服务器的 Windows 服务获取从 RSReportServer.config 文件的所在。 有关所在的详细信息,请参阅"更多信息"一节。 方法 4升级到 64 位版本的 Microsoft SQL Server 2005年报告服务。 方法 5重新设计该报表。若要执行此操作,请使用下列方法之一。 方法 A重新设计报表查询。通过重新设计报表查询,通过以下方法,可以减少内存消耗: 方法 B将报表导出为其他格式。通过使用不同的格式来显示报表,您可以减少内存占用。下表列出了几个按顺序从大多数内存消耗到最低的内存消耗的导出格式。 方法 C简化报表设计。可以通过以下方式简化报表设计减少内存消耗: 示例下面的示例演示了如何解决此问题。请考虑下面的示例: 1.以 PDF 格式,并以 Excel 格式,无法呈现在报表管理器返回 160 页的报告。当使用 8.5 × 11 英寸页面尺寸时,报表可能远远超过 250 页。 若要解决此问题,在此示例中,重新设计报表,以显示该报表仅为有限的一组筛选器值的汇总数据。此外,请确保聚合发生在报告数据中提取数据库查询和聚合中的报告本身不是。这些方法有助于大大减少到报表服务器返回的数据量。因此,成功地并更快地呈现报表。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |