Пример: студент может посещать множество курсов, и один курс может посещать множество студентов. То есть связь между студентом и курсом - многий ко многим. В классе студент, помимо всего прочего, есть public List<CourseModel> Courses { get; set; } = new List<CourseModel>(); Если в при таком раскладе в классе Course ничего не писать про студентов, то создается связь много к одному (то есть на курсе может быть только 1 студент, т.к. в модели курса в базе создается дополнительное поле, в котором хранится ключ студента.) Я добавил в модель класса CourseModel
[ForeignKey("Students")]
public virtual List<int> studentsIds { get; set; }
При попытке добавить миграцию вылетает ошибка
The property 'CourseModel.studentsIds' could not be mapped because it is of type 'List<int>', which is not a supported primitive type or a valid entity type. Either explicitly map this property, or ignore it using the '[NotMapped]' attribute or by using 'EntityTypeBuilder.Ignore' in 'OnModelCreating'.
Пробовал менять тип List на IEnumerable и ICollection - тоже самое. Как мне реализовать эту связь? По сути мне не обязательно хранить в модели курса всех студентов, слущающих этот курс, но EntityFramework в таком случае создает неверную связь.
Три таблицы: студенты, курсы и студент на курсе с уникальными парами курс - студент.
Обсуждают сегодня