Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
2 / 2 / 0
Регистрация: 06.03.2013
Сообщений: 99

Внешние ключи

08.06.2014, 21:14. Показов 1485. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.В качестве поля в родительской таблице может быть любое поле ?Или есть какие то требования к нему ??Спасибо
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.06.2014, 21:14
Ответы с готовыми решениями:

Внешние ключи
Всем доброе время суток. Использую MySQL 5.5+. Столкнулся со следующей проблемой. В первой таблице есть колонка "N" и есть...

Внешние ключи в MySQL
у меня есть таблица articles: create table articles( id int not null auto_increment, category_id int not null, title...

С чем едят внешние ключи?
Решил впервые сделать базу с внешними ключами. Набил таблиц со связями, попытался импортировать ее через phpMyAdmin и ничего, PMA выдает...

13
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
09.06.2014, 09:50
BelkaLetyaga, желательно (по смыслу ссылки) первичный ключ.

Минимально - UNIQUE NOT NULL
0
2 / 2 / 0
Регистрация: 06.03.2013
Сообщений: 99
09.06.2014, 10:43  [ТС]
т.е. желательно,чтобы он был первичный?

Добавлено через 17 минут
А если у меня в родительской таблице оно обычное поле,а в дочерней первичный ключ,мне как решить эту ситуацию?
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
09.06.2014, 10:50
Покажи структуры таблиц
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
09.06.2014, 11:02
BelkaLetyaga, смысл ссылок (references) в том, что есть справочник с уникальными записями, на который ссылаются из кучи разных мест.

Вопрос: почему в вашем справочнике не уникальный ключ? Как обеспечить в "дочерних" таблицах получение одинаковй информации из "родительской", если в ней нет ПК (то есть записи неуникальны или могут не существовать)?
0
2 / 2 / 0
Регистрация: 06.03.2013
Сообщений: 99
09.06.2014, 11:51  [ТС]
ALTER TABLE `table1` ADD FOREIGN KEY(t1_id) REFERENCES table2(`t2_id`) если t1_id первичный ключ ,а t2_id просто поле не уникальное,так будет ошибка?

точнее,t2_id уникальное поле,но не является первичным ключем,и теоретически не может быть NULL
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
09.06.2014, 11:57
Цитата Сообщение от BelkaLetyaga
t2_id уникальное поле,но не является первичным ключем,и теоретически не может быть NULL
А чем по сути отличается unique not null от PK?

PS
"Теоретически не м.б. NULL" и "объявлено NOT NULL" - это для СУБД не одно и то же
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
09.06.2014, 12:00
Цитата Сообщение от Grossmeister Посмотреть сообщение
А чем по сути отличается unique not null от PK?
кластерный индекс или не кластерный?

Хотя ПК тоже может быть некластерным...

А, вот: ПК один, а UNIQUE -много
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
09.06.2014, 13:08
Цитата Сообщение от cygapb-007 Посмотреть сообщение
А, вот: ПК один, а UNIQUE -много
А м.б. нужен просто составной PK?
Поэтому я и просил показать структуру таблиц. А чисто по словесному описанию что-то странное: нет PK, но есть unique not null
0
2 / 2 / 0
Регистрация: 06.03.2013
Сообщений: 99
09.06.2014, 15:32  [ТС]
А если в дочерней таблице FK и PK это одно и то же поле?Это корректно?
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
09.06.2014, 16:20
Цитата Сообщение от BelkaLetyaga Посмотреть сообщение
А если в дочерней таблице FK и PK это одно и то же поле?
Скорее всего, ты путаешься в понятиях. Но без структуры таблиц все это лишь догадки
0
2 / 2 / 0
Регистрация: 06.03.2013
Сообщений: 99
09.06.2014, 16:27  [ТС]
А значение FK в поле может быть NULL?
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
09.06.2014, 16:33
Цитата Сообщение от BelkaLetyaga Посмотреть сообщение
ALTER TABLE `table1` ADD FOREIGN KEY(t1_id) REFERENCES table2(`t2_id`) если t1_id первичный ключ ,а t2_id просто поле не уникальное,так будет ошибка?
точнее,t2_id уникальное поле,но не является первичным ключем,и теоретически не может быть NULL
В этой схеме:

table2 - справочник: любое значение t2_id встречается в нем не более 1 раза. Для гарантии этого поле t2_id не должно быть пустым (NOT NULL) и должно быть уникальным. Оптимальный вариант - PRIMARY KEY

table1 - использует значения из справочника по ссылке на него в поле t1_id. Поле t1_id должно быть того же типа, что и поле t2_id - больше никаких требований к нему не предъявляется.
Если значение в нем NULL - в справочник не лезем (там нет NULL по определению), а значит это допустимое значение.
Если значение не NULL (например, 94) - то MySQL проверит, есть ли такое значение в справочнике:
exists(select 1 from table2 where t2_id=94)
если не найдет - сгенерирует ошибку, если найдет - добавит/изменит запись в table1
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
09.06.2014, 16:35
Цитата Сообщение от BelkaLetyaga Посмотреть сообщение
А значение FK в поле может быть NULL?
В большинстве случаев да (хотя и зависит от бизнес-условий). Например, родительская таблица department (отделы) и дочерняя - employee (сотрудники). Сотрудник имеет ссылку на отдел, в котором он работает. Если ссылка пустая, это можно трактовать как то, что сотрудник в настоящий момент не приписан ни к какому отделу.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.06.2014, 16:35
Помогаю со студенческими работами здесь

Внешние ключи в связке Аксесс2003-MySQL
Форумчане, доброго времени суток! Вопрос наверно очень простой, а именно: Перенес данные из таблиц Аксесс 2003 на MySQL. Оказалось...

Почему у меня не устанавливаются внешние ключи?
почему у меня не устанавливаются внешние ключи? ALTER TABLE Книги ADD FOREIGN KEY R_2 (Код_издательства) REFERENCES Издательство...

Не создаются внешние ключи для таблицы в phpmyadmin
хочу создать 2 внешних ключа в таблице marks: marks.numbDiscip->kafedry.numbDiscip marks.numbTeacher->teacher.numb но выдает...

Какая версия сервера поддерживает внешние ключи, ... ?
Какая версия сервера поддерживает внешник ключи, хранимые процедуры, триггеры и домены ?

Внешние ключи Cascade: При записи в таблицу тикетс — все записывается, а при записи в hub - ошибка
Никак не могу разобраться со связями и внешними ключами в базе. Ограничение на ключи сделал Cascade проблема в том что при записи...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru