c# - EF7 beta6 : Error saving multiple entities

标签 c# asp.net-core entity-framework-core

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

无法跟踪“公司”,因为已跟踪具有相同 key 的此类型的另一个实例。对于新实体,请考虑使用 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() 或更改映射来解决它,但是如果我尝试在多个请求中更新多个实体,我得到异常:

  1. 第一个请求:更新 CompanyId 8
  2. 第一个请求:更新 CompanyId 9 !!错误

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

最佳答案

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

我将存储库添加为单例:

services.AddSigleton<Data.Interfaces.Company.ICompanyRepository,Data.Repositories.Company.CompanyRepository>();

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

解决:

services.AddScoped<Data.Interfaces.Company.ICompanyRepository,Data.Repositories.Company.CompanyRepository>();

关于c# - EF7 beta6 : Error saving multiple entities,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31392842/

相关文章:

c# - 验证登录用户新输入的密码

c# - 如何从 Xml 文件中获取逗号分隔值

c# - Nuget 包 "Not available in this source"... 但 VS 仍然知道它?

asp.net-core - 在运行时启用/禁用 SwaggerUI

entity-framework-core - 需要更新 EF Core 工具

.net-core - 为什么在 Entity Framework Core 中使用 FindAsync 时会出现空引用异常?

c# - "empty line with semicolon"在 C# 中意味着什么?

c# - 从 ContentControl 中使用的 Ioc 的 viewModel 中释放内存

c# - 如何向 ASP.NET Core 应用程序提交文件

c# - 使用类作为关系时如何创建复合(主)键