Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/34: Рейтинг темы: голосов - 34, средняя оценка - 4.88
 Аватар для Игорюня
20 / 16 / 11
Регистрация: 07.12.2013
Сообщений: 244

Entity Framework 6. Code First. Связь один-ко-многим и многие-ко-многим одновременно

30.05.2015, 05:56. Показов 6699. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здрасти. Есть таблица юзеров и объявлений. У юзера может быть множество объявлений. Здесь действует связь
один-ко-многим. Но юзер также может помечать чужие объявления в избранные, то есть у юзера может быть множество избранных объявлений, и объявление может быть избранным у многих юзеров. Здесь действует связь многие-ко-многим.
Тут получается, что нужно создать между этими двумя таблица как связь один-ко-многим и также многие-ко-многим.

Вот тут код, показывающий связи между моделями:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class User
{
   public int Id { get; set; }
 
   //связь один ко многим
   public virtual ICollection<Advert> Adverts{ get; set; }//обычные объявления юзера
 
   //связь многие ко многим
   public virtual ICollection<Advert> ChosenAdverts { get; set; }//избранные объявления юзера
}
 
public class Advert
{
   public int Id{ get; set; }
 
   //связь один ко многим
   public int? UserId{ get; set; }
   public virtual User User{ get; set; }//владелец объявления
 
   //связь многие ко многим
 
   public virtual ICollection<User> SelectedUsers { get; set; }//множество избравших юзеров
}
Собственно, как EF6 сможет понять, какая связь куда относится? Мне кажется, что тут образуется каша.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.05.2015, 05:56
Ответы с готовыми решениями:

Связь многие-ко-многим в Entity Framework
делаю задания с моделями сущностей entity framework. на примере студентов и курсов, у каждого студента может быть несколько курсов, как и у...

Связь многие ко многим (Entity Framework)
Мне нужна связь многие ко многим. Нашел вот тут хороший туториал который объясняет как ее сделать на Entity Framework. Но не понятно что...

Entity Framework. Связь между таблицами один ко многим
Здравствуйте. Столкнулся с такой проблемой - у меня есть таблицы Тестов и Вопросов (к тестам), связь один ко многим. Реализация следующая...

1
 Аватар для m@cChe
45 / 45 / 26
Регистрация: 15.05.2013
Сообщений: 226
Записей в блоге: 1
31.05.2015, 17:14
Игорюня, переопределите в контексте функцию
C#
1
OnModelCreating(DbModelBuilder modelBuilder)
и настройте в связи как Вам угодно.

Добавлено через 3 часа 16 минут
пример:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Entity<User>()
                 .HasMany(c => c.ChosenAdverts)
                 .WithMany(c => c.SelectedUsers )
                 .Map(m =>
                 {
                     m.MapLeftKey("AdvertsId");
                     m.MapRightKey("UserId");
                     m.ToTable("UsersAdverts");
                 });
 
            base.OnModelCreating(modelBuilder);
        }
вроде того.

http://metanit.com/sharp/entityframework/3.4.php
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.05.2015, 17:14
Помогаю со студенческими работами здесь

Entity framework, связь многие ко многим
Доброго времени суток ! Зарание извиняюсь если поместил тему не в тот раздел. Вопрос такой у меня есть 2 таблицы со связкой...

Entity Framework связь один-ко-многим
Приветствую! Имеется две модели (со связью один-ко-многим): public class Menu { public int Id { get;...

Entity Framework многие-ко-многим
Добрый день! Прошу прощения, если создал тему не в том разделе. Ситуация такая: Использую EF CodeFirst. Есть классы, которые...

Связь многие ко многим EntityFramework Code First
Всем привет! Столкнулся с проблемой при проектировании БД со связью многие-ко-многим. Ситуация следующая: есть врачи и есть мед....

Entity Framework в модель не добавляется таблица со связью многие ко многим
Всем привет. Проблема в следующем, в модель представления данных Entity Framework не могу добавить таблицу со связью многие ко многим....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru