Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
Всем привет! Нужна помощь в создании внешнего ключа для соединения двух таблиц! создал 2 таблицы create table boys ( boy varchar(30) default null ); insert into boys values ('дейви'), ('бобби'), ('бивер'), ('ричи'); и create table toys ( toy varchar(30) default null ); insert into toys values ('обруч'), ('самолет'), ('солдатики'), ('губная гармошка'), ('бейсбольные карточки'); потом понял, что не доделал и внес изменения, первичные ключи и поменял местами столбцы alter table boys add column boy_id int auto_increment primary key; alter table boys modify column boy varchar(30) after boy_id; alter table toys add column toy_id int not null auto_increment primary key; alter table toys modify column toy varchar(30) after toy_id; Принял для себя , что boys это главная таблица а toys дочерняя , поэтому хочу добавить внешний ключ таблице toys. Не могу понять как таблице toys сделать внешний ключ , чтобы эти таблицы были связаны. спасибо заранее. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 17:50 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
dermama, Покажите результат SHOW CREATE TABLE после всех ваших манипуляций. И поясните какое поле с каким должно быть связано внешним ключем. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 17:54 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
miksoftdermama, Покажите результат SHOW CREATE TABLE после всех ваших манипуляций. И поясните какое поле с каким должно быть связано внешним ключем. немного не понял что вы имете ввиду, то есь я хочу чтобы boy_id было primary key, а toy_id было foreign key. Исходя из того, что у меня уже сделано. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 18:12 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
Неужели было сложно текстом скопипастить? dermamaхочу чтобы boy_id было primary key, а toy_id было foreign keyТехнически сделать это несложно: Код: sql 1. Но смысла я в этом не вижу. Довольно редко бывает нужно, чтобы первичный ключ одной таблицы ссылался на первичный ключ другой таблицы. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 18:46 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
miksoftНеужели было сложно текстом скопипастить? dermamaхочу чтобы boy_id было primary key, а toy_id было foreign keyТехнически сделать это несложно: Код: sql 1. Но смысла я в этом не вижу. Довольно редко бывает нужно, чтобы первичный ключ одной таблицы ссылался на первичный ключ другой таблицы. А поччему вы не использовали ограничение Constraint, я просто только изучаю и мне интересно как это работает, но во всех случаях я видел Constraint. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 19:04 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
dermamaА поччему вы не использовали ограничение Constraint, я просто только изучаю и мне интересно как это работает, но во всех случаях я видел Constraint.В нем просто задается имя ограничения, оно необязательно. Если нужно - используйте. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 19:16 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
dermamadermama, Таки научитесь копипастить текстом. Поскольку вы уже навставляли данных в таблицы, то в toys.toy_id образовалось значение, которого нет в boys.boy_id. А при наличии внешнего ключа такое недопустимо. Вот он и не создается. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 19:18 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
тогда как мне его создать тебе? что удалить что изменить, как это сделать) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 19:51 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
dermamaчто удалить что изменить, как это сделать)самое простое - удалить все записи из таблицы toys. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 19:54 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
получается если я присваиваю таблице ,которая должна иметь внешний ключ, основной ключ и заполняю ее, то присвоить внешний ключ ей уже не получится? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 20:07 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
dermamaтогда как мне его создать тебе? что удалить что изменить, как это сделать) ни тебе , а теперь, прошу прощения) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 20:07 |
|
||
|
Внешний ключ
|
|||
|---|---|---|---|
|
#18+
dermamaполучается если я присваиваю таблице ,которая должна иметь внешний ключ, основной ключ и заполняю ее, то присвоить внешний ключ ей уже не получится?Получится только при условии, что в поле toys.toy_id не будет значений, которых нет в boys.boy_id. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2018, 20:17 |
|
||
|
|

start [/forum/topic.php?fid=47&msg=39664891&tid=1829774]: |
0ms |
get settings: |
10ms |
get forum list: |
13ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
43ms |
get topic data: |
10ms |
get forum data: |
3ms |
get page messages: |
45ms |
get tp. blocked users: |
1ms |
| others: | 13ms |
| total: | 146ms |

| 0 / 0 |
