Как создать внешний ключ в SQL: подробное руководство для начинающих

Чтобы создать внешний ключ в SQL, вам нужно использовать ключевое слово FOREIGN KEY в операторе ALTER TABLE.

Вот пример, показывающий, как создать внешний ключ в SQL:


    ALTER TABLE таблица_1
    ADD CONSTRAINT имя_ограничения FOREIGN KEY (столбец_1)
    REFERENCES таблица_2(соответствующий_столбец_2);
    

В приведенном выше примере, таблица_1 это таблица, в которой вы хотите создать внешний ключ, имя_ограничения это имя, которое вы выбираете для ограничения, столбец_1 это столбец в таблице_1 и таблица_2 это таблица, на которую вы ссылаетесь с помощью внешнего ключа, и соответствующий_столбец_2 это соответствующий столбец в таблице_2.

Детальный ответ

Как создать внешний ключ SQL?

Внешний ключ (foreign key) - это ключ в базе данных, который связывает две таблицы между собой. Он определяет отношения между данными в разных таблицах и обеспечивает ссылочную целостность данных.

Создание внешнего ключа SQL требует определения связи между двумя таблицами, где одна таблица будет иметь ключ, ссылающийся на ключ другой таблицы. Давайте рассмотрим процесс создания внешнего ключа подробнее:

Шаг 1: Создание таблиц

Прежде чем создавать внешний ключ, необходимо иметь две таблицы. Возьмем для примера две таблицы: "users" и "orders". Таблица "users" будет содержать информацию о пользователях, а таблица "orders" - о заказах, сделанных этими пользователями.


CREATE TABLE users (
    id INT PRIMARY KEY,
    name VARCHAR(50),
    email VARCHAR(50)
);

CREATE TABLE orders (
    id INT PRIMARY KEY,
    user_id INT,
    product VARCHAR(50),
    FOREIGN KEY (user_id) REFERENCES users(id)
);
    

В приведенном выше примере мы создали две таблицы "users" и "orders". У таблицы "users" есть первичный ключ "id", который представляет уникальный идентификатор каждого пользователя. В таблице "orders" у нас также есть первичный ключ "id", а также внешний ключ "user_id", который ссылается на ключ "id" таблицы "users".

Шаг 2: Определение внешнего ключа

Для определения внешнего ключа мы используем ключевое слово "FOREIGN KEY", за которым следует название столбца, на который мы хотим установить внешний ключ. Затем мы используем ключевое слово "REFERENCES", за которым идет название таблицы и столбца, на который мы хотим сослаться.

В нашем примере мы определяем внешний ключ "user_id" в таблице "orders", который ссылается на ключ "id" в таблице "users". Таким образом, каждая запись в таблице "orders" будет иметь значение "user_id", которое существует в столбце "id" таблицы "users".

Шаг 3: Управление внешним ключом

После создания внешнего ключа SQL позволяет нам управлять им с помощью различных операций. Некоторые из них:

  • ON DELETE CASCADE: Эта операция позволяет автоматически удалять связанные записи в таблице-потомке при удалении записи из таблицы-родителя. Например, если мы удаляем пользователя из таблицы "users", все его заказы будут автоматически удалены из таблицы "orders".
  • ON UPDATE CASCADE: Эта операция позволяет автоматически обновлять значения в таблице-потомке при обновлении значения в таблице-родителе.
  • ON DELETE SET NULL: Эта операция устанавливает значения внешнего ключа NULL, когда связанная запись в таблице-родителе удаляется.

Чтобы определить одну из этих операций, вам нужно добавить ключевое слово "ON DELETE" или "ON UPDATE" после ключевого слова "REFERENCES". Например:


CREATE TABLE orders (
    id INT PRIMARY KEY,
    user_id INT,
    product VARCHAR(50),
    FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE
);
    

В приведенном выше примере мы добавили "ON DELETE CASCADE", чтобы автоматически удалять связанные записи в таблице "orders", когда запись в таблице "users" удаляется.

Вывод

Создание внешнего ключа SQL - важный аспект базы данных, который помогает связать две таблицы и обеспечить ссылочную целостность данных. Процесс создания внешнего ключа включает создание таблиц, определение внешнего ключа и управление им с помощью различных операций. Помните, что определение внешнего ключа является ключевым шагом для создания связей между таблицами и обеспечения правильной организации данных.

Видео по теме

Первичный ключ, внешний ключ, суррогатный ключ / Илья Хохлов

Создание Foreign key - внешний ключ - для PostgreSQL (2021)

Базы данных. SQL. MySQL: Внешние ключи

Похожие статьи:

Как создать процедуру SQL: пошаговая инструкция для начинающих

Как создать внешний ключ в SQL: подробное руководство для начинающих

Как связать базу данных SQL с Visual Studio: полное руководство для начинающих

Как удалить Microsoft SQL Server Management Studio 18: пошаговая инструкция