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);
执行代码没有使用多线程
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
好吧,最后发现还是和并发访问有关。EF本身不是线程安全,当进行并发操作时,有可能会导致SaveChanges出现这种错误,或是DbSet出现该错误。看EF的源代码是因为它之中的DetectConflicts引起的。总之就是对EF的操作时要注意线程安全