Как задать связи разного вида с помощью Foreign key?
Ну то есть, стандартное назначение key для внешнего ключа и последующее описание внешнего ключа приводит к связи 1 к 1, но как дать понять, что связь 1 ко многим или многие ко многим?
Артем Прохоров, Не совсем. Вы указали версию СУБД, но не её название. MySQL, PostgreSQL, MS SQL, Oracle Database, IBM DB2 и т.д. Эти СУБД имеют отличия за пределами ANSI SQL.
Но, судя по версии, у вас MySQL.
Для правильного вопроса надо знать половину ответа
В MySQL внешний ключ (Foreign Key) служит только для дополнительного автоматического контроля целостности базы. В подчинённой таблице поле не может принимать значение, не входящее в список значений связанного поля родительской таблицы или NULL.
Тип связи в MySQL не учитывается.
Артем Прохоров, Связь 1:1, как правило, не делается. Связь n:n стандартно строится как две связи 1:n с промежуточной таблицей. Так что, можно считать, что все связи имеют тип 1:n.
Написано
Войдите на сайт
Чтобы задать вопрос и получить на него квалифицированный ответ.