- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在 C# 中有一个长时间运行的进程,它访问 Sql 表 10 到 200 次。当进程每次从同一个表中超过大约 50 次点击和查询超过大约 100,000 行时,它将在此行抛出系统内存不足异常,特别是在将 IQuery 对象转换为列表的底部:
var cht = from p in _db.TickerData
where p.Time >= Convert.ToDateTime(start) &&
p.Time <= Convert.ToDateTime(end)
orderby p.Time
select p;
_prices = cht.ToList(); < this is where the System.OutofMemoryException occurs >
我能做些什么来防止这个错误??
最佳答案
首先:
specifically at the bottom where it converts the IQuery object to a List
是的,这就是您预计会发生内存不足情况的地方。
cht
的赋值以上实际上并没有访问数据库;它所做的只是声明查询的形状。这称为延迟执行,LINQ 到处都在使用它。这意味着“在您的代码需要它之前,我们实际上不会处理任何东西。”
调用 ToList
, 不过,本质上是说“代码现在需要它,全部需要它。”所以这就是它将查询发送到数据库的地方,一次拉回所有结果,使用 LINQ 魔法将它们转换为 CLR 对象,并将它们全部填充到 List<T>
中。给你。
话虽如此,这只是一种预感,但您的 LINQ 提供程序可能不知道什么 Convert.ToDateTime
是。如果它不知道如何处理,它不会将它放入它执行的查询中的 WHERE 子句中,而是加载整个表并在客户端对其进行过滤,这可能就是当表 变得太大,而不是当结果集 变得太大。
要验证这一点,请为您的数据库使用分析器来拦截查询,并查看 WHERE 子句是否符合您的预期。如果翻译不正确,请试试这个:
var startTime = Convert.ToDateTime(start);
var endTime = Convert.ToDateTime(end);
var cht = from p in _db.TickerData
where p.Time >= startTime && p.Time <= endTime
orderby p.Time
select p;
_prices = cht.ToList();
如果这没有帮助,您可能只是撤回了太多数据,您将不得不以与在任何其他环境中处理过多数据相同的方式进行处理。
关于c# - Linq System.OutofMemoryException 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32681094/
我已经花了几周的时间来解决这个问题。但我仍然无法解决这个问题。 我在 angularjs 中使用 http 调用 Web API 服务 $http({
我的转储文件包含 OutOfMemoryException 但所有对象字段似乎都为空。这只是一个误报还是有办法知道这个异常(exception)? 0:052> !do 000000027fff10e
我使用的项目包含许多从单个基类继承的类。在单元测试中,我需要按类型和数据比较收到的结果。 当我在条件列表包含足够多的不同条件的情况下使用类型匹配比较时,编译器会抛出 OutOfMemoryExcept
我的应用程序在 512mb 手机模拟器上运行时突然崩溃(可重现)(只有 920 来测试)。没有任何异常,它只是变黑了。然后我在应用程序上运行分析工具,发现内存在应用程序崩溃时达到了极限。应用程序退出并
我试图弄清楚应该如何使用 MemoryCache 以避免出现内存不足异常。我来自 ASP.Net 背景,缓存管理它自己的内存使用,所以我希望 MemoryCache 会做同样的事情。正如我制作的波纹管
我从某个生产代码版本中获得了异常日志。 System.OutOfMemoryException: Exception of type 'System.OutOfMemoryException' was
比如说,我们有一个表,其中包含一些包含 jpg 文件二进制数据的大型 text 字段。任务是从磁盘上的数据库中获取这些文件。因此,起初我决定执行以下操作: MyDataContext dc = new
在 Windows 窗体 C# 应用程序中,我有一个文本框,用户可以在其中粘贴日志数据,并对其进行排序。我需要单独检查每一行,所以我按新行拆分输入,但如果有很多行,超过 100,000 行左右,它会抛
我们正在将一个大的平面文件加载到 BizTalk Server 2006(原始版本,不是 R2)中 - 大约 125 MB。我们针对它运行一个映射,然后获取每一行并调用一个存储过程。 我们在编排处理期
比如说,我们有一个表,其中包含一些包含 jpg 文件二进制数据的大型 text 字段。任务是从磁盘上的数据库中获取这些文件。因此,起初我决定执行以下操作: MyDataContext dc = new
在我的应用程序中,用户可以启动相机 Intent 并拍照并将其保存到自定义文件夹中。然后他们可以重新启动相机拍摄另一张照片等。因此最终用户可以拍摄多张照片。 我遇到的问题是,在我的画廊中,当我尝试将所
在 Windows 窗体 C# 应用程序中,我有一个文本框,用户可以在其中粘贴日志数据,并对其进行排序。我需要单独检查每一行,所以我按新行拆分输入,但如果有很多行,超过 100,000 行左右,它会抛
我收到 OutOfMemoryException,而堆似乎仍然有足够的剩余空间。 我自己的日志报告 - VM 内存使用了 48G 中的 22.28G 来自-XX:+PrintGCDetails -XX
给定一个简单的案例类 case class Rating(user: Int, item: Int, rating: Double) 和两个RDD[Rating]:我们得到的 OOME 在两个 R
我正在开发一个应用程序,该应用程序使用移动设备拍照并使用网络服务发送照片。但是在我拍了 4 张照片之后,我在下面的代码中得到了一个 OutOfMemoryException。我尝试调用 GC.Coll
我想调整我网站中图片的大小,但是当我使用 Bitmap 加载 14032*19864(png 扩展名)的图片时,抛出 OutOfMemoryException。我的编译器配置是 any cpu。我在怀
在我的应用程序中,我正在使用 Windows 服务读取文件。该服务每秒读取一次文件。这是我用来读取文件的代码: public static byte[] GetBytesFromFile(string
我正在尝试将用户的整个桌面捕获为图像。我通过以下方式执行此操作: public Bitmap CaptureScreen() { // Set up a bit
我正在开发一个 64 位 .Net Windows 服务应用程序,该应用程序本质上加载了一堆数据以供处理。在执行数据量测试时,我们能够压倒该进程并抛出 OutOfMemoryException(我没有
我知道我的问题没有简单的答案,但我会很感激想法、指南或某种要看的东西列表 我有一个不断抛出 OutOfMemoryException 异常的网络 Windows 服务。该服务有两个针对 x86 和 x
我是一名优秀的程序员,十分优秀!