仓储工作单元使用过程中的问题
出现错误,如截图
出现错误,如截图
相关组件为Microsoft.EntityFrameworkCore.UnitOfWork.dll ,当同时删除很多个实体,需用到IRepository中的dbset.RemoveRange(Icollection<Tentity>)的方法,经过多次尝试均出现上图所示错误。
然后从git库下载了Microsoft.EntityFrameworkCore.UnitOfWork的源码,发现其中的delete方法逻辑如下:
然后从git库下载了Microsoft.EntityFrameworkCore.UnitOfWork的源码,发现其中的delete方法逻辑如下:
public virtual void Delete(IEnumerable<TEntity> entities) => _dbSet.RemoveRange(entities);
后再谷歌百度多番查找,找到解决方案。修改Repository.cs中的Delete(IEnumerable<TEntity> entities)方法,代码如下:
主要思路是删除实体之前先将其添加到dbset中,attach的作用:贴出链接,自己看。https://docs.microsoft.com/en-us/dotnet/api/system.data.entity.dbset.attach?redirectedfrom=MSDN&view=entity-framework-6.2.0#overloads
其中的原因:现在还没有全部理解,就不误导大家了。如果有大佬解释解释就更不好不过了。
public virtual void Delete(IEnumerable<TEntity> entities) { List<TEntity> resultList=new List<TEntity>(); foreach (var entity in entities) { resultList.Add( _dbSet.Attach(entity)); } _dbSet.RemoveRange(resultList); }
主要思路是删除实体之前先将其添加到dbset中,attach的作用:贴出链接,自己看。https://docs.microsoft.com/en-us/dotnet/api/system.data.entity.dbset.attach?redirectedfrom=MSDN&view=entity-framework-6.2.0#overloads
其中的原因:现在还没有全部理解,就不误导大家了。如果有大佬解释解释就更不好不过了。
博客参考: