EF7 beta6:保存多个实体时出错

我正在使用ASP.NET5和Entity Framework 7.0.0-beta 6创建API,当我尝试在多个请求中执行各种更新时,我得到了以下exception:

无法跟踪“公司”,因为已经跟踪了具有相同密钥的此类型的另一个实例。 对于新实体,请考虑使用IIdentityGenerator生成唯一键值。

这是我的代码:

public class MrBellhopContext : DbContext { public DbSet Company { get; set; } protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity(entity => { entity.Key(c => c.CompanyId); entity.Index(c => c.Name); entity.Property(c => c.CompanyId).ValueGeneratedOnAdd(); }); modelBuilder.UseSqlServerIdentityColumns(); base.OnModelCreating(modelBuilder); } } public class Company { public int CompanyId { get; set; } public string Name { get; set; } public string Description { get; set; } public string Phone { get; set; } public string Email { get; set; } public short StatusId { get; set; } } public class CompanyRepository : ICompanyRepository { MrBellhopContext _dbcontext; public async Task UpdateAsync(Company company) { _dbcontext.Update(company); await _dbcontext.SaveChangesAsync(); } } [Route("api/[controller]")] public class CompanyController : Controller { [HttpPut] public async void UpdateAsync([FromBody] Company company) { if ((!ModelState.IsValid) || (company == null)) { Context.Response.StatusCode = 400; return; } else { await _repository.UpdateAsync(company); } } } 

我试图通过删除ValueGeneratedOnAdd()UseSqlServerIdentityColumns()或更改映射来解决它,但如果我尝试更新多个请求中的多个实体,我会得到exception:

  1. 首要求:更新CompanyId 8
  2. 首先要求:更新CompanyId 9 !! 错误

有谁知道如何解决这个问题?

已解决: https : //github.com/aspnet/EntityFramework/issues/2652

我将Repository添加为Singleton:

 services.AddSigleton(); 

这意味着所有请求都共享存储库的单个实例。 您应该将其减少为Scoped,以便每个请求都有一个存储库实例。 除了避免您遇到的问题之外,它还将确保您最终不会有一个巨大的上下文实例跟踪内存中数据库中的所有数据。

要解决:

 services.AddScoped(); 

您收到此错误是因为您的_repository实例已在内存中具有相同键的Company实例。 当您跨线程重用DbContext实例时,可能会发生这种情况。 上面的示例不包含有关如何实例化CompanyController._repository的代码。 确保HTTP请求之间不共享此项。

另外,在配置密钥之前放置此行。

 entity.Property(c => c.CompanyId).ValueGeneratedOnAdd(); 

即使我面临同样的问题。

我在startup.cs文件的Configure方法中将存储库注册为单例。 将其更改为AddScoped解决问题。

只需要使用下面的代码来更新记录

 _dbContext.Company.Update(company); _dbContext.SaveChanges();