>  기사  >  데이터 베이스  >  mysql 외래 키 및 삭제

mysql 외래 키 및 삭제

WBOY
WBOY원래의
2023-05-18 12:25:08708검색

MySQL 외래 키 및 삭제

MySQL은 널리 사용되고 매우 강력한 일반적으로 사용되는 관계형 데이터베이스 관리 시스템입니다. MySQL에서 외래 키는 매우 중요한 개념이며 데이터베이스 설계 및 데이터 유지 관리에 중요한 역할을 합니다. 이 기사에서는 MySQL의 외래 키를 소개하고 외래 키를 사용하여 데이터베이스의 데이터를 삭제하는 방법을 소개합니다.

MySQL 외래 키

외래 키는 한 데이터베이스 테이블에 다른 테이블의 기본 키를 가리키는 키를 설정하는 것을 의미합니다. 테이블에 외래 키가 있는 경우 이 테이블의 각 정규 레코드에 해당하는 기본 테이블 레코드가 존재해야 하며, 그렇지 않으면 관련 작업을 수행할 수 없습니다. 이 작업은 테이블 간 데이터의 무결성과 일관성을 보장합니다.

다음 예를 통해 외래 키의 개념을 설명합니다.

person 테이블 만들기:

CREATE TABLE person (
    id INT PRIMARY KEY,
    name VARCHAR(20)
);

테이블 카드 만들기:

CREATE TABLE card (
    id INT PRIMARY KEY,
    person_id INT,
    card_no VARCHAR(20),
    FOREIGN KEY(person_id) REFERENCES person(id)
);

테이블 카드에서 person_id는 person 테이블의 id 필드를 가리키는 외래 키입니다. 이 외래 키의 목적은 각 카드 기록의 person_id가 개인 테이블에 존재하는지 확인하여 일관성과 무결성을 보장하는 것입니다.

외래 키를 사용하여 삭제

데이터베이스를 삭제할 때 테이블 간에 관계가 있는 경우 삭제 작업으로 인해 데이터베이스의 무결성과 일관성이 파괴되지 않도록 해야 합니다. MySQL에서는 외래 키를 사용하여 이를 달성할 수 있습니다.

삭제 작업을 수행할 때 삭제할 레코드가 외래 키와 연결된 테이블에 존재하는 경우 먼저 연결된 테이블의 레코드를 삭제한 후 이 테이블의 레코드를 삭제해야 합니다. 이 프로세스는 ON DELETE CASCADE 및 ON DELETE SET NULL의 두 가지 방법으로 구현될 수 있습니다.

ON DELETE CASCADE는 연관 테이블의 레코드가 삭제되면 이 테이블의 관련 레코드를 자동으로 분류하여 삭제하는 방식으로 작동합니다. 예:

CREATE TABLE person (
    id INT PRIMARY KEY,
    name VARCHAR(20)
);

CREATE TABLE card (
    id INT PRIMARY KEY,
    person_id INT,
    card_no VARCHAR(20),
    FOREIGN KEY(person_id) REFERENCES person(id) ON DELETE CASCADE
);

INSERT INTO person(id, name) VALUES(1, 'Tom');

INSERT INTO card(id, person_id, card_no) VALUES(1, 1, '123456');

DELETE FROM person WHERE id = 1;

위 예에서는 먼저 개인 테이블에 레코드를 삽입한 다음 카드 테이블에 레코드를 삽입했습니다. 이 레코드는 개인 테이블의 ID가 1인 레코드를 가리킵니다. 마지막으로 DELETE 문을 사용하여 개인 테이블에서 ID가 1인 레코드를 삭제했습니다. 이 삭제 작업은 카드 테이블의 관련 레코드도 자동으로 삭제합니다.

ON DELETE SET NULL 연산은 관련 테이블의 레코드가 삭제되면 해당 테이블의 관련 레코드가 NULL로 설정되는 작업입니다. 예:

CREATE TABLE person (
    id INT PRIMARY KEY,
    name VARCHAR(20)
);

CREATE TABLE card (
    id INT PRIMARY KEY,
    person_id INT,
    card_no VARCHAR(20),
    FOREIGN KEY(person_id) REFERENCES person(id) ON DELETE SET NULL
);

INSERT INTO person(id, name) VALUES(1, 'Tom');

INSERT INTO card(id, person_id, card_no) VALUES(1, 1, '123456');

DELETE FROM person WHERE id = 1;

위 예에서는 먼저 개인 테이블에 레코드를 삽입한 다음 카드 테이블에 레코드를 삽입했습니다. 이 레코드는 개인 테이블의 ID가 1인 레코드를 가리킵니다. 마지막으로 DELETE 문을 사용하여 person 테이블에서 ID가 1인 레코드를 삭제했습니다. 이 삭제 작업은 카드 테이블의 관련 레코드에 있는 person_id를 자동으로 NULL로 설정합니다.

요약

MySQL 외래 키는 매우 중요한 개념이며 데이터베이스 설계 및 데이터 유지 관리에 중요한 역할을 합니다. 외래 키를 사용하면 테이블 간 데이터의 무결성과 일관성을 보장할 수 있습니다. 삭제 작업을 수행할 때 ON DELETE CASCADE 및 ON DELETE SET NULL을 사용하여 테이블 간의 연결을 처리하여 데이터베이스 일관성을 보장할 수 있습니다.

위 내용은 mysql 외래 키 및 삭제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.