【发布时间】:2015-07-13 20:29:33
【问题描述】:
我正在使用 ASP.NET5 和 Entity Framework 7.0.0-beta 6 创建一个 API,当我尝试在多个请求中执行各种更新时,我得到了这个异常:
无法跟踪“公司”,因为已在跟踪另一个具有相同键的此类实例。对于新实体,请考虑使用 IIdentityGenerator 生成唯一键值。
这是我的代码:
public class MrBellhopContext : DbContext
{
public DbSet<Company> Company { get; set; }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Company>(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() 或更改映射来解决它,但如果我尝试在多个请求中更新多个实体,我获取异常:
- 第一个请求:更新 CompanyId 8
- 第一个请求:更新 CompanyId 9 !!错误
有人知道如何解决这个问题吗?
【问题讨论】:
-
已尝试将
[Key]属性添加到主键属性,在您的情况下为ComapnyId? -
该错误表明您有两个具有相同 ID 的 Company 实例。通过查看您的代码看起来不像这种情况,但我不能确定。你能告诉调用者 UpdateAsync 吗?
-
@Bart 是的,当然。我包括代码。
-
我认为在执行第一个操作后,DBContext 中还有一些东西还活着;当我执行第二个时,失败
标签: c# asp.net-core entity-framework-core