Я пытаюсь обновить коллекцию ProjectEmployees внутри ProjectModel. Я хочу удалить все старые значения и установить новые.Entity Framework Core - связанная с обновлением коллекция
Мои модели:
public class Project
{
...
public ICollection<ProjectEmployee> ProjectEmployees { get; set; }
}
public class ProjectEmployee
{
public int ProjectId { get; set; }
public virtual Project Project { get; set; }
public int UserId { get; set; }
public virtual Employee Employee { get; set; }
}
public class Employee
{
public int UserId { get; set; }
public User User { get; set; }
...
}
public class ProjectGroupModel //ViewModel
{
public int ProjectId { get; set; }
public ICollection<Employee> ProjectEmployees { get; set; }
}
Это типично многие-ко-многим.
Мои действия контроллера:
[HttpPost("group")]
public async Task<IActionResult> CreateGroup([FromBody] ProjectGroupModel pro)
{
var dbProject = await _context.Project
.Include(p=>p.ProjectEmployees)
.FirstAsync(p => p.ProjectId == pro.ProjectId);
dbProject.ProjectEmployees.Clear();
foreach (var emp in pro.ProjectEmployees)
{
dbProject.ProjectEmployees.Add(new ProjectEmployee()
{
UserId = emp.UserId
});
}
await _context.SaveChangesAsync();
return Ok();
}
Когда pro.ProjectEmployees пуста все записи из dbProject.ProjectEmployees были удалены правильно, и если dbProject.ProjectEmployees пуста новые записи из модели были добавлены, но когда dbProject.ProjectEmployees не пусто Я не могу установить новые записи:
ОШИБКА:
"The instance of entity type 'ProjectEmployee' cannot be tracked because another instance of this type with the same key is already being tracked. When adding new entities, for most key types a unique temporary key value will be created if no key is set (i.e. if the key property is assigned the default value for its type). If you are explicitly setting key values for new entities, ensure they do not collide with existing entities or temporary values generated for other new entities. When attaching existing entities, ensure that only one entity instance with a given key value is attached to the context."
Я попытался исправить это действие в сотни но всегда это неправильно.
следует преобразовать dbProject в список с помощью метода ToList. а затем попробуйте обновить его. –
Мне кажется, что это конфликты с первичными ключами. Когда вы создаете новый ProjectEmployee(), вы устанавливаете только UserId. Не следует ли также установить ProjectId? –
Что такое PK для 'ProjectEmployee'? –