如果您正在跟踪大量实体在上下文中并调用方法之一很多时候在循环中,然后可能会显著的性能改进通过关闭更改检测循环的持续时间。
不要忘记重新启用更改检测循环后的,我们使用了 try/finally 来确保始终重新启用即使循环中的代码引发异常。
System.Text.StringBuilder result = new System.Text.StringBuilder(); using (Time100Entities db = new Time100Entities()) { var now1 = DateTime.Now.TimeOfDay; result.Append(string.Format("<p>{0}开始将数据Add到上下文中</p>", now1)); //方案1:EF默认会自动的跟踪数据的变化,当变更的数据量较大的时候,EF的跟踪工作量就会骤增,指定操作变得缓慢 db.Configuration.AutoDetectChangesEnabled = false; //禁用自动检测更改 db.Configuration.ValidateOnSaveEnabled = false; for (int i = 0; i < 100; i++) { EntityModel.F_Order api = new EntityModel.F_Order(); api.OrderCode = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss fff"); api.AddTime = DateTime.Now; db.F_Order.Add(api); } //方案2:AddRange解决EF插入的性能问题 //List<EntityModel.F_Order> orderList = new List<EntityModel.F_Order>(); //db.F_Order.AddRange(orderList); var now2 = DateTime.Now.TimeOfDay; result.Append(string.Format("<p>{0}数据Added完毕,开始执行Insert操作,耗时{1}</p>", now2, now2 - now1)); result.Append(string.Format("<p>AutoDetectChangesEnabled 状态:{0}</p>", db.Configuration.AutoDetectChangesEnabled)); try { db.SaveChanges(); } finally { db.Configuration.AutoDetectChangesEnabled = true; db.Configuration.ValidateOnSaveEnabled = true; } var now3 = DateTime.Now.TimeOfDay; result.Append(string.Format("<p>{0}Insert完毕,耗时{1}</p>", now3, now3 - now2)); Response.Write(result); }
官网说明:https://docs.microsoft.com/zh-cn/ef/ef6/saving/change-tracking/auto-detect-changes
分类:
Entity Framework
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
2009-06-06 Jquery 局部刷新及 表单取值赋值 处理返回json数据 一些基本操作
2007-06-06 WinRAR 命令行备份SQLserver数据库文件 或者Vss源代码数据库目录······
2007-06-06 如何每天自动备份 SourceSafe !