ADO.NET EF 4.2 中的查询缓存(避免查询缓存)

文章详细介绍了在WinForm系统中使用Entity Framework遇到的问题,即查询缓存导致数据库更新后,Form2窗口仍显示旧数据的情况。通过引入AsNoTracking方法,避免了缓存干扰,确保了数据一致性,并且提高了性能。
摘要由CSDN通过智能技术生成

在WinForm系统中遇到了个问题,Form1是查询窗口,根据条件查询出所有数据,双击列表后创建弹出Form2窗口编辑单个记录,但编辑后保存后,在Form2中查询到的还是旧的数据,实际数据库中已经更新了,怀疑是4.2中加了查询缓存功能。

用ILSpy查看EntityFramework程序集,发现 System.Data.Entity.DbExtensions有个AsNoTracking的扩展方法,试了一下果然解决了。比如这样使用:

  var people = context.People.Where(p => p.PersonID > 100).AsNoTracking().ToList();

如果是取单个非追踪的实体,也可以这样:

return (from m in _dataContext.Monkeys.AsNoTracking()
        where m.MonkeyId == monkeyId
        select m).FirstOrDefault();

原来此举还能提高性能 :) 因为AsNoTracking后查询结构实体不被EF Context追踪,当然不追踪的实体也就不能用Update更新了,好在一般查询列表的也不需要更新。

关于AsNoTracking使用的问题,可以参看 LingzhiSun’s Blog 的这个POST(http://www.cnblogs.com/LingzhiSun/archive/2011/04/27/EF_Trick4.html)。

和这个Using DbContext in EF 4.1 Part 11: Load and AsNoTracking (http://blogs.msdn.com/b/adonet/archive/2011/02/05/using-dbcontext-in-ef-feature-ctp5-part-11-load-and-asnotracking.aspx)

还有这个http://stackoverflow.com/questions/4911000/turn-off-object-caching-in-entity-framework-ctp5

再搜索了一下,有个同学在08年还专门做了个”Caching the results of LINQ queries

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值