我使用的是EF 5.0,并且有一个通用的上下文:
namespace ComTr.Web.BusinessLayer
{
public class GenericRepository<TEntity> : IDisposable where TEntity : ComTrBaseEntity //Use as base class to allow access to base entities properties like modified
{
internal ComTrContext Context;
internal DbSet<TEntity> DbSet;
public GenericRepository()
{
Context = new ComTrContext();
DbSet = Context.Set<TEntity>();
}
public virtual TEntity GetById(object id)
{
return DbSet.Find(id);
}
/// <summary>
/// Edits the specified entity to update. Will attach entity to the context
/// </summary>
/// <param name="entityToUpdate">The entity to update.</param>
/// <returns></returns>
public virtual TEntity Edit(TEntity entityToUpdate)
{
entityToUpdate.Modified = DateTime.Now;
DbSet.Attach(entityToUpdate);
Context.Entry(entityToUpdate).State = EntityState.Modified;
return entityToUpdate;
}
}
}
现在我尝试使用以下代码更新单个值:
var ComBookingRespository = new ComBookingRespository();
comBooking= ComBookingRespository.GetById(adventureBookingId);
////Save Token in database
comBooking.PaymentToken = token;
ComBookingRespository.Edit(comBooking);
VS将停在以下一行:
Context.Entry(entityToUpdate).State = EntityState.Modified;
以下错误消息:
IEntityChangeTracker的多个实例
无法引用实体对象
这很奇怪,因为我没有其他参考(因为你可以看到上下文是新启动的)。 我怎么能摆脱这个?
答案 0 :(得分:2)
您的错误可能来自PaymentToken实体。
您有一个令牌实体,您附加到adventureBooking
。可能,您通过不同的通用存储库获得该实体,使用相同的逻辑 - 您在该存储库中创建了一个上下文并检索了该项。由于令牌实体已附加到您的TokenRepository
,并且您的adventureBooking
实体已附加到您的comBookingRepository
,因此您有两种不同的上下文。要么将token
实体与其原始存储库断开连接,要么重载您的存储库以便能够传递您的上下文,以便在您的存储库之间共享您的上下文。
public GenericRepository(DbContext context)
{
Context = context;
DbSet = Context.Set<TEntity>();
}
然后在您的代码中创建您的回购:
var context = new new ComTrContext();
var ComBookingRespository = new ComBookingRespository(context );
var tokenRepository = new tokenRepository (context );
答案 1 :(得分:0)
您的上下文的另一个实例是跟踪相关实体。