Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 17.07.2014
Сообщений: 129

Пытаюсь соединить таблицы внешним ключом - ввыдает ошибку

19.08.2015, 01:38. Показов 1624. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Я им соединение а они мне вот что:

#1452 - Cannot add or update a child row: a foreign key constraint fails (`cddelop11659`.`#sql-cc4_239`, CONSTRAINT `#sql-cc4_239_ibfk_3` FOREIGN KEY (`id_city`) REFERENCES `city` (`id_city`))


таблицы innodb

таблица city
id_city smalint (10) primary key autoinkremen
city varchar
country_id


таблица vakans
id_vak int (5) primary key autoinkremen
koment varchar
id_firm int (5)
id_dol int (5)
id_city smalint (10)


хочу соеденить тве таблицы с помощью поля id_city . таблица city как бы справочник а vakans "рабочяя" таблица.
в обе таблицы было внесено несколько записей.
Что не так?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.08.2015, 01:38
Ответы с готовыми решениями:

Добавление в таблицы объединенные внешним ключом
Пожалуйста, скажите, что не так???????

Заполнение таблицы с внешним ключом
Добрый день. Имею следующие таблицы: (фото 1) И имею запрос на сохранение в таблицу basket: try { ...

Ошибка #150 при создании таблицы с внешним ключом
Всем доброго времени суток, в чём проблема, уже битый час не могу понять, 1 таблица создаётся, но вот во второй ошибка #150, почему? Ведь...

6
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
19.08.2015, 09:46
Цитата Сообщение от davidoff72 Посмотреть сообщение
в обе таблицы было внесено несколько записей
Какие значения записаны в vakans.id_city? Соответствуют ли они city.id_city?
1
0 / 0 / 0
Регистрация: 17.07.2014
Сообщений: 129
19.08.2015, 11:30  [ТС]
сначало я создал таблицу vakans без поля id_city и внес в эту таблицу несколько записей.
потом решил добавить поле для внешнего ключа id_city и связать с таблицей city. во всех ранее созданных строках в поле vakans.id_city значение - 0.
Поля соответствуют друг другу.
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
19.08.2015, 11:52
Цитата Сообщение от davidoff72
ранее созданных строках в поле vakans.id_city значение - 0.
Поля соответствуют друг другу.
А значение city.id_city = 0 есть?
1
0 / 0 / 0
Регистрация: 17.07.2014
Сообщений: 129
19.08.2015, 12:58  [ТС]
нет, в таблице vakans.id_city значение - 0

пример:

таблица city
id_city 1 2
city Москва Санкт Птрбург
country_id (внешний ключ на страну)

таблица vakans
id_vak 1
koment хорошая вакансия
id_firm (внешний ключ на таблицу firm)
id_dol (внешний ключ на таблицу dol)
id_city 0
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
19.08.2015, 13:22
Лучший ответ Сообщение было отмечено davidoff72 как решение

Решение

Цитата Сообщение от davidoff72 Посмотреть сообщение
нет, в таблице vakans.id_city значение - 0
Вот в этом и дело. Основное назначение FK - обеспечить, чтобы в дочерней таблице не было значений, которых нет в родительской. Поэтому при нулевых значениях ключ не создается (в родительской такого значения нет). Либо надо ручками проставить корректные значения в дочерней таблице, либо вообще удалить из нее строки. Тогда FK можно будет создать.
1
0 / 0 / 0
Регистрация: 17.07.2014
Сообщений: 129
19.08.2015, 14:11  [ТС]
Да, Вы правы! Спасибо!
действительно, внес вручную значения и таблицы соединились. Из этого следует - "береги честь с молоду...", то есть, надо заранее продумывать всю архитектуру. Хорошо у меня было 10 тренировочных записей. а если бы сто тысяч ...ввести в ручную это больно или чего хуже грохнуть базу в 100 000 записей - это может привести в отчаяние.

Да, жизнь жестока.
Спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.08.2015, 14:11
Помогаю со студенческими работами здесь

Пытаюсь связать таблицы, выдаёт ошибку
Код ошибки: Таблица "Предмет" сохранена успешно таблица "Отметки" - Не удалось создать связь "FK_Отметки_Предмет". ...

В таблицах с внешним ключом ошибки(
Добрый день. У меня возникает ошибка при заполнении таблицы с внешним ключом. Причем, если убрать внешний ключ при создании таблицы, то...

Добавление записи с внешним ключом в БД
Привет всем! Нужен совет, а то не получается кое-что. Такой трабл: есть две таблички - users и addresses. В addresses есть поле id_user,...

Добавить запись в таблицу с внешним ключом
Есть 3 таблицы: Category(idCategory, name), таблица Providers(idProviders, name, adress, phoneNumber) и таблица Products(idProduct, name,...

Django трудность с внешним ключом и базой данных
https://ibb.co/drAgUb Ситуация показана на картинке. Я делаю форму в DJANGO для заполнения нового объекта студент. Но вместо номера...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru