С Новым годом! Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/34: Рейтинг темы: голосов - 34, средняя оценка - 4.94
0 / 0 / 0
Регистрация: 24.12.2010
Сообщений: 124

Создание связей в phpMyAdmin

24.01.2018, 20:26. Показов 6834. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер.
Не могу разобраться со связями, выходит наоборот, нежели я хочу сделать. Связи один-ко_многим Не пойму в чем подвох.

Вот пример базы данных: https://pastebin.com/d1BxSTZ3

К примеру table1 это таблица юзеров, где столбец id его уникальный идентификатор, name - имя.

table2 к примеру содержит метаданные юзера, где столбец id_table это идентификатор (id) из table1.

Если я открываю структуру table1 и нажимаю "связи" и создаю такую связь:
SQL
1
ALTER TABLE `table1` ADD FOREIGN KEY (`id`) REFERENCES `table2`(`id_table`) ON DELETE RESTRICT ON UPDATE RESTRICT;
То она спокойно создается, но наоборот. Например если я из table1 удалю строку с id = 51, то из table2 не удаляться строчки с id_table = 51.
А если в table2 удалю строку с id_table = 51, то в table1 удаляться строчки с id = 51.

Если я открываю структуру table2 и нажимаю "связи" и делаю такую связь:
SQL
1
ALTER TABLE `table2` ADD  FOREIGN KEY (`id`) REFERENCES `table2`(`id_table`) ON DELETE RESTRICT ON UPDATE RESTRICT;
То вылетает ошибка:
SQL
1
#1452 - Cannot ADD OR UPDATE a child ROW: a FOREIGN KEY CONSTRAINT fails (`test`.`#sql-1d98_aee`, CONSTRAINT `#sql-1d98_aee_ibfk_1` FOREIGN KEY (`id`) REFERENCES `table2` (`id_table`))
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.01.2018, 20:26
Ответы с готовыми решениями:

Про создание связей
Связи между таблицами бывают разные : один к одному, один ко многим, многие ко многим но, все связи создаются с помощью FOREIGN KEY...

Создание связей в базе данных
Здравствуйте! Пожалуйста, помогите мне с одной проблемой. Значит, мне нужно создать базу данных, где будут храниться регионы, города и...

Создание связей между таблицами
Здравствуйте! Имеется схема (см. скрин). При попытке INSERT получаем ошибку (см. скрин). Как решается проблема? P.S. схема...

4
411 / 365 / 142
Регистрация: 09.04.2011
Сообщений: 1,051
24.01.2018, 21:10
Цитата Сообщение от pie Посмотреть сообщение
То она спокойно создается, но наоборот. Например если я из table1 удалю строку с id = 51, то из table2 не удаляться строчки с id_table = 51.
А если в table2 удалю строку с id_table = 51, то в table1 удаляться строчки с id = 51.
так и должно быть, внешний ключ в дочерней таблице

Цитата Сообщение от pie Посмотреть сообщение
То вылетает ошибка:
ссылаетесь на саму себя
ALTER TABLE `table2` .. REFERENCES `table2`..
0
0 / 0 / 0
Регистрация: 24.12.2010
Сообщений: 124
24.01.2018, 21:30  [ТС]
По поводу ошибки да, неправильно просто задал.
Вот такой запрос:
SQL
1
ALTER TABLE `table2` ADD  FOREIGN KEY (`id_table`) REFERENCES `table1`(`id`) ON DELETE CASCADE ON UPDATE CASCADE;
И вот такая ошибка:
SQL
1
#1452 - Cannot ADD OR UPDATE a child ROW: a FOREIGN KEY CONSTRAINT fails (`test`.`#sql-2594_8b`, CONSTRAINT `#sql-2594_8b_ibfk_1` FOREIGN KEY (`id_table`) REFERENCES `table1` (`id`) ON DELETE CASCADE ON UPDATE CASCADE)
А по поводу так и должно быть - думаю нет.
В данном случае мне нужно получить так:
table1 - родительский объект;
table2 - потомок.

Таким образом все изменения в table1 должны отражаться в table2. Поменял идентификатор (id) в table1, он должен поменяться и в table2 (в строке id_table). А в моем случае как раз получается наоборот. Не понимаю почему.

Вот еще пример.
table1:
id | name
1 | Жигули

table2:
id | id_table1 | name
1 | 1 | колесао
2 | 1 | дверь

В этом случае если я в table1 удалю строку id = 1, то в таблице table2 должны удалиться строки с id_table1 = 1.
Как сделать так?
0
476 / 239 / 114
Регистрация: 12.05.2016
Сообщений: 647
24.01.2018, 21:59
SQL
1
И вот такая ошибка:
Таблицы пустые или с данными? Если с данными - проверяйте корректность. Нельзя наложить внешний ключ на таблицы с кривыми данными.

Тип у таблиц какой? Поди у одной из таблиц MyISAM ? Этот движок не поддерживает внешние ключи.
0
411 / 365 / 142
Регистрация: 09.04.2011
Сообщений: 1,051
24.01.2018, 22:02
Цитата Сообщение от pie Посмотреть сообщение
Вот такой запрос:
SQLВыделить код
1
ALTER TABLE `table2` ADD FOREIGN KEY (`id_table`) REFERENCES `table1`(`id`) ON DELETE CASCADE ON UPDATE CASCADE;
И вот такая ошибка:
SQLВыделить код
1
#1452 - Cannot ADD OR UPDATE a child ROW: a FOREIGN KEY CONSTRAINT fails (`test`.`#sql-2594_8b`, CONSTRAINT `#sql-2594_8b_ibfk_1` FOREIGN KEY (`id_table`) REFERENCES `table1` (`id`) ON DELETE CASCADE ON UPDATE CASCADE)
см Ошибки внешних ключей
При попытке добавить внешний ключ на таблицу, в которой есть записи, не удовлетворяющие условию внешнего ключа (т.е. не имеющие соответствия в родительской таблице)
в вашем случае это (2, 55)

Добавлено через 2 минуты
Цитата Сообщение от pie Посмотреть сообщение
В этом случае если я в table1 удалю строку id = 1, то в таблице table2 должны удалиться строки с id_table1 = 1.
Как сделать так?
сделать внешний ключ на table2, вы даже запрос правильный пишите, осталось только данные привести в соответствие с ограничением внешнего ключа.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.01.2018, 22:02
Помогаю со студенческими работами здесь

Создание связей после переиндексации таблицы
Здравствуйте гютоварищи программисты. У меня такая задача с виду простая, но я ни где не нашёл га неё ответа. В общем есть две таблицы....

Создание запроса в phpMyAdmin
Здравствуйте! В процессе обучения поставлена задача создать БД "Персонал" с 3 таблицами. В каждой таблице 3 поля: "возраст",...

Создание базы в phpMyAdmin из файла .sql
Здравствуйте. Как в phpMyAdmin создать базу данных, но не "в ручную", а выполнением внешнего файла .sql, в котором находятся все команды...

Создание диаграммы связей
Всем привет. МОжно ли создать ER-диаграмму не создавая новую БД? БД уже создана

Правильное создание связей между таблицами
Здравствуйте! Подскажите, как будет правильнее создать связи между таблицами? Например: Имеется 3 таблицы: Пользователи...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru