EF 使用 POCO中的对象状态跟着
EF4.1中,有DbChangeTracker对象,
在设置ctx.Configuration.ProxyCreationEnabled = true|false; 两种取值时发现调整实体类属性时都能正确跟着
使用代理类着可以理解,因为代理类可以截获属性的修改,但是不使用代理类是居然也可以。。。
没有去看DBChangeTracker的具体实现,不过推测应该通过轮训机制或者通过在SaveChange等方法调用前执行内存中的快照与当前实体实际属性值比较来实现。
var ctx = new lineDBContext(); ctx.Configuration.ProxyCreationEnabled = false; ctx.Configuration.LazyLoadingEnabled = false; ctx.Configuration.AutoDetectChangesEnabled = true; var items = ctx.PersonClasses.ToList(); items[0].ClassName = "333"; Console.WriteLine(items[0].People.Count); Console.WriteLine(items[1].People.Count); var bhd= ctx.ChangeTracker.Entries<PersonClass>().ToList(); // items[0].ClassName = "333"; 放在这里将显示两个对象都是Unchanged状态,可见Entries<T>()方法会调用DetectChanges() Console.WriteLine(bhd[0].State); Console.WriteLine(bhd[1].State);
参考:
http://blogs.msdn.com/b/adonet/archive/2011/02/06/using-dbcontext-in-ef-feature-ctp5-part-12-automatically-detecting-changes.aspx
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述