Форум программистов, компьютерный форум, киберфорум
Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
 Аватар для Serg34
100 / 100 / 33
Регистрация: 20.09.2014
Сообщений: 457
Записей в блоге: 3

Связь "Многие ко многим". Нужна ли четвертая таблица?

16.06.2015, 14:41. Показов 1242. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Представлю свою задачу в виде детской задачи (дабы терминами не грузить-они не важны).
Есть несколько групп из трех детей.
Их кормят по определенному меню:
Перед первым дают на выбор салат или бутерброд, на первое- суп или борщ, на второе всегда только чай.

В первой группе Петя выбирает всегда Салат, Борщ и Чай; Ваня выбирает Салат, Суп, второе не ест и т.д.
Подскажите, плиз, как правильнее реализовать такую связь?

Еще: в таблице Foods не должно быть строк больше, чем сейчас
Будет ли хорошим тоном создать еще таблицу? (см. рисунок)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.06.2015, 14:41
Ответы с готовыми решениями:

Связь один ко многим или многие к многим
Добрового времени суток, помогите создать связь в SQL management studio. Значит есть одна таблица с названием "TypeOfDocuments"...

Entity Framework 6. Code First. Связь один-ко-многим и многие-ко-многим одновременно
Здрасти. Есть таблица юзеров и объявлений. У юзера может быть множество объявлений. Здесь действует связь один-ко-многим. Но юзер также...

Связь многие ко многим
Сначала про базу данных. Существует несколько таблиц, есть главная таблица(транспортный лист) вокруг которой все остальные...

4
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
16.06.2015, 16:28
для развязки отношения m:n всегда используется только одна граничная сущность
0
 Аватар для Serg34
100 / 100 / 33
Регистрация: 20.09.2014
Сообщений: 457
Записей в блоге: 3
17.06.2015, 09:50  [ТС]
pincet, то есть добавлять четвертую таблицу неправильно?
Цитата Сообщение от pincet Посмотреть сообщение
отношения m:n
Разве тут только отношение m:n? Разве не какое-то m:n:k?
Сложно объяснить-я только с прошлой недели начал в базы данных углубляться.
Разъясните, пожалуйста, и как лучше поступить в моей ситуации?
Может, пример есть (я сам нашел только тривиальные примеры)?
А вотЗдесь, например, еще одну таблицу внедряют.
Не совсем пойму как без нее обойтись....
0
2895 / 1930 / 208
Регистрация: 05.06.2011
Сообщений: 5,667
21.06.2015, 08:14
Стоит начать с того, что вот так — group, child1, child2, child3 — таблицы не делают. Не рассчитаны на такое ни СУБД, ни SQL. Удохнешь в мало-мальски реальном примере. Такие таблицы вытягиваются вертикально: group, child, при этом одна и та же группа повторяется много раз для каждого ребёнка. Это, собственно, таблица связи. Если связь один-ко-многим (не стоит задача учесть переводы из группы в группу), можно её объединить с таблицей детей. Ну и так далее, по всем таблицам.
0
 Аватар для Serg34
100 / 100 / 33
Регистрация: 20.09.2014
Сообщений: 457
Записей в блоге: 3
21.06.2015, 13:49  [ТС]
Видимо, я вас запутал.
На самом деле ребенок1, реб2, реб3- это пустые поля (созданы, чтобы Entity Framework автоматически создал подобные свойства для класса Groups-наверно, это тоже зло вопиющее), которые будут заполняться в ходе выполнения программы. То есть поле ребенок1 группы0 будет содержать значение (в моем примере это салат или борщ) в зависимости от того, какое блюдо (закуска, первое или второе) выберет пользователь для конкретной группы.
То есть, значения "петя", "Вася" и т.д. на самом деле будут сначала пустыми, а потом будут заполнены салатами, борщами и т.д.
Вся эта тягомотина из-за переменчивости меню (Например, салат"оливье" завтра может стать Салатом"цезарь", но ребенок1 группы0 так и будет есть салат перед первым)
На самом деле там еще сложнее всё, видимо не по зубам мне пока такие орешки-я хотел для портфолио прогу написать, но боюсь, что только облажаюсь. Спасибо за ответы
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.06.2015, 13:49
Помогаю со студенческими работами здесь

Связь многие ко многим
День добрый. Есть 2 таблицы "описание" и "адрес" и связь многое ко многим. При выполнении запроса, вместо необходимых адресов выдает весь...

Связь многие-ко-многим
Здравствуйте, вопрос есть по поводу SQL запроса. Есть 2 таблицы, предметы и студенты. Один предмет могут посещать несколько студентов и...

Связь многие ко многим
Помогите пожалуйста! Создала таблицы в Database desktop(->Paradox7) Taблицы: Выдача, Книги, Читатели Как мне их связать три сразу в...

Связь Многие Ко Многим
Добрый день, нужен совет по оптимизации работы: Лотус иерархическая система, однако иногда приходится использовать связи многие ко...

Связь многие ко многим
Есть Users и Course. делаю связь многие ко многим. Пользователь входит на странице courses.ftl , где отображаются курсы и рядом с ними...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru