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 중국어 웹사이트의 기타 관련 기사를 참조하세요!