|
2 / 2 / 0
Регистрация: 06.03.2013
Сообщений: 99
|
|
Внешние ключи08.06.2014, 21:14. Показов 1485. Ответов 13
Метки нет (Все метки)
Здравствуйте.В качестве поля в родительской таблице может быть любое поле ?Или есть какие то требования к нему ??Спасибо
0
|
|
| 08.06.2014, 21:14 | |
|
Ответы с готовыми решениями:
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 | ||
PS "Теоретически не м.б. NULL" и "объявлено NOT NULL" - это для СУБД не одно и то же
0
|
||
|
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
|
||
| 09.06.2014, 12:00 | ||
|
Хотя ПК тоже может быть некластерным... А, вот: ПК один, а UNIQUE -много
0
|
||
|
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
|
||
| 09.06.2014, 13:08 | ||
![]() Поэтому я и просил показать структуру таблиц. А чисто по словесному описанию что-то странное: нет 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 | ||
|
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 | ||
|
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 | ||
|
0
|
||
| 09.06.2014, 16:35 | |
|
Помогаю со студенческими работами здесь
14
Внешние ключи в связке Аксесс2003-MySQL Почему у меня не устанавливаются внешние ключи? Не создаются внешние ключи для таблицы в phpmyadmin Какая версия сервера поддерживает внешние ключи, ... ? Внешние ключи Cascade: При записи в таблицу тикетс — все записывается, а при записи в hub - ошибка Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модель заражения группы наркоманов
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.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|