EntityFrameWork对DbSet进行AddRange和RemoveRange时空引用错误

查看:211
本文介绍了EntityFrameWork对DbSet进行AddRange和RemoveRange时空引用错误的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

使用EntityFrameWork对DbSet进行AddRange或RemoveRange时,大概每10000次会有1次报NullReferenceException错误

看报错信息是再EntityFrameWork中的ObjectStateManager中的DetectConflicts报错

代码如下

private DbSet<T> m_Set;

var adds = m_EntityState.FindAll(e => e.State == EntityState.Added).Select(e => e.DataEntiy);
m_Set.AddRange(adds);
var removes = m_EntityState.FindAll(e => e.State == EntityState.Deleted).Select(e => e.DataEntiy);
m_Set.RemoveRange(removes);

执行代码没有使用多线程

解决方案

好吧,最后发现还是和并发访问有关。EF本身不是线程安全,当进行并发操作时,有可能会导致SaveChanges出现这种错误,或是DbSet出现该错误。看EF的源代码是因为它之中的DetectConflicts引起的。总之就是对EF的操作时要注意线程安全

这篇关于EntityFrameWork对DbSet进行AddRange和RemoveRange时空引用错误的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆