MySQL에서 외래 키는 두 테이블의 데이터 간의 연결을 설정하고 강화하는 데 사용되는 하나 이상의 열입니다. 이는 한 테이블의 필드가 다른 테이블의 필드에서 참조된다는 것을 나타냅니다. 외래 키는 관련 테이블의 데이터에 제한을 두어 MySQL이 참조 무결성을 유지할 수 있도록 합니다.
이 튜토리얼의 운영 환경: windows7 시스템, mysql8 버전, Dell G3 컴퓨터.
외래 키는 기본 키에 상대적입니다.
기본 키 테이블의 행을 고유하게 식별하는 속성 또는 속성 그룹입니다. 테이블에는 기본 키가 하나만 있을 수 있지만 후보 인덱스는 여러 개 있을 수 있습니다. 기본 키는 데이터 불일치를 방지하기 위해 외래 키와 함께 참조 무결성 제약 조건을 형성하는 경우가 많습니다. 기본 키를 사용하면 레코드가 고유하고 기본 키 필드가 비어 있지 않은지 확인할 수 있습니다. 데이터베이스 관리 시스템은 기본 키에 대한 고유 인덱스를 자동으로 생성하므로 기본 키도 특수 인덱스입니다.
외래 키는 두 테이블의 데이터 간의 연결을 설정하고 강화하는 데 사용되는 하나 이상의 열입니다. 외래 키는 한 테이블의 필드가 다른 테이블의 필드에서 참조된다는 의미입니다. 외래 키는 관련 테이블의 데이터에 제한을 두어 MySQL이 참조 무결성을 유지할 수 있도록 합니다.
외래 키 제약 조건은 주로 두 테이블 간의 데이터 일관성을 유지하는 데 사용됩니다. 즉, 한 테이블의 외래 키는 다른 테이블의 기본 키가 되고, 외래 키는 두 테이블을 연결하는 역할을 합니다. 일반적인 상황에서 테이블의 기본 키를 삭제하려면 먼저 다른 테이블에 동일한 외래 키가 없는지 확인해야 합니다. 즉, 테이블의 기본 키에 연결된 외래 키가 없는지 확인해야 합니다.
외래 키를 정의할 때 다음 규칙을 준수해야 합니다.
메인 테이블은 데이터베이스에 이미 존재하거나 현재 생성 중인 테이블이어야 합니다. 후자의 경우 마스터 테이블과 슬레이브 테이블이 동일한 테이블인 경우, 이러한 테이블을 자기 참조 테이블이라고 하며, 이러한 구조를 자기 참조 무결성이라고 합니다.
기본 테이블에 대한 기본 키를 정의해야 합니다.
기본 키에는 null 값이 포함될 수 없지만 외래 키에는 null 값이 허용됩니다. 즉, null이 아닌 모든 외래 키 값이 지정된 기본 키에 나타나는 한 외래 키의 내용은 정확합니다.
메인 테이블의 테이블 이름 뒤에 컬럼 이름을 지정하거나 컬럼 이름의 조합을 지정하세요. 이 열 또는 열 조합은 기본 테이블의 기본 키 또는 후보 키여야 합니다.
외래 키의 열 수는 기본 테이블의 기본 키의 열 수와 동일해야 합니다.
외래 키에 있는 열의 데이터 유형은 기본 테이블의 기본 키에 있는 해당 열의 데이터 유형과 동일해야 합니다.
MySQL 외래 키 생성 구문
다음 구문은 CREATE TABLE
문의 하위 테이블에 외래 키를 정의하는 방법을 보여줍니다. CREATE TABLE
语句中的子表中定义外键。
CONSTRAINT constraint_name FOREIGN KEY foreign_key_name (columns) REFERENCES parent_table(columns) ON DELETE action ON UPDATE action
下面我们来更详细的查看上面语法:
CONSTRAINT
子句允许您为外键约束定义约束名称。如果省略它,MySQL将自动生成一个名称。FOREIGN KEY
子句指定子表中引用父表中主键列的列。您可以在FOREIGN KEY
子句后放置一个外键名称,或者让MySQL为您创建一个名称。 请注意,MySQL会自动创建一个具有foreign_key_name
名称的索引。REFERENCES
子句指定父表及其子表中列的引用。 在FOREIGN KEY
和REFERENCES
中指定的子表和父表中的列数必须相同。ON DELETE
子句允许定义当父表中的记录被删除时,子表的记录怎样执行操作。如果省略ON DELETE
子句并删除父表中的记录,则MySQL将拒绝删除子表中相关联的数据。此外,MySQL还提供了一些操作,以便您可以使用其他选项,例如ON DELETE CASCADE,当删除父表中的记录时,MySQL可以删除子表中引用父表中记录的记录。 如果您不希望删除子表中的相关记录,请改用ON DELETE SET NULL
操作。当父表中的记录被删除时,MySQL会将子表中的外键列值设置为NULL
,条件是子表中的外键列必须接受NULL
值。 请注意,如果使用ON DELETE NO ACTION
或ON DELETE RESTRICT
操作,MySQL将拒绝删除。ON UPDATE
子句允许指定在父表中的行更新时,子表中的行会怎样执行操作。当父表中的行被更新时,可以省略ON UPDATE
子句让MySQL拒绝对子表中的行的任何更新。 ON UPDATE CASCADE
操作允许您执行交叉表更新,并且当更新父表中的行时,ON UPDATE SET NULL
操作会将子表中行中的值重置为NULL
值。 ON UPDATE NO ACTION
或UPDATE RESTRICT
CREATE DATABASE IF NOT EXISTS dbdemo; USE dbdemo; CREATE TABLE categories( cat_id int not null auto_increment primary key, cat_name varchar(255) not null, cat_description text ) ENGINE=InnoDB; CREATE TABLE products( prd_id int not null auto_increment primary key, prd_name varchar(355) not null, prd_price decimal, cat_id int not null, FOREIGN KEY fk_cat(cat_id) REFERENCES categories(cat_id) ON UPDATE CASCADE ON DELETE RESTRICT )ENGINE=InnoDB;
CONSTRAINT
절을 사용하면 외래 키 제약 조건에 대한 제약 조건 이름을 정의할 수 있습니다. 생략하면 MySQL이 자동으로 이름을 생성합니다. FOREIGN KEY
절은 상위 테이블의 기본 키 열을 참조하는 하위 테이블의 열을 지정합니다. FOREIGN KEY
절 뒤에 외래 키 이름을 배치하거나 MySQL이 자동으로 이름을 생성하도록 할 수 있습니다. MySQL은 foreign_key_name
이라는 이름의 인덱스를 자동으로 생성합니다.
REFERENCES
절은 상위 테이블과 해당 하위 테이블의 열에 대한 참조를 지정합니다. FOREIGN KEY
및 REFERENCES
에 지정된 하위 테이블과 상위 테이블의 열 수가 동일해야 합니다. 🎜🎜 ON DELETE
절을 사용하면 상위 테이블의 레코드가 삭제될 때 하위 테이블의 레코드가 작업을 수행하는 방법을 정의할 수 있습니다. ON DELETE
절을 생략하고 상위 테이블의 레코드를 삭제하면 MySQL은 하위 테이블의 관련 데이터 삭제를 거부합니다. 또한 MySQL은 상위 테이블의 레코드를 삭제할 때 🎜ON DELETE CASCADE🎜와 같은 추가 옵션을 사용할 수 있도록 몇 가지 작업도 제공합니다. MySQL은 상위 테이블의 레코드를 참조하는 하위 테이블의 레코드를 삭제할 수 있습니다. 하위 테이블에서 관련 레코드를 삭제하지 않으려면 대신 ON DELETE SET NULL
작업을 사용하세요. 상위 테이블의 레코드가 삭제되면 MySQL은 하위 테이블의 외래 키 열이 NULL</을 허용해야 하는 경우 하위 테이블의 외래 키 열 값을 <code>NULL
로 설정합니다. 코드> >값. ON DELETE NO ACTION
또는 ON DELETE RESTRICT
작업이 사용되는 경우 MySQL은 삭제를 거부합니다. 🎜🎜 ON UPDATE
절을 사용하면 상위 테이블의 행이 업데이트될 때 하위 테이블의 행에 어떤 일이 발생하는지 지정할 수 있습니다. 상위 테이블의 행이 업데이트될 때 MySQL이 하위 테이블의 행에 대한 모든 업데이트를 거부하도록 ON UPDATE
절을 생략할 수 있습니다. ON UPDATE CASCADE
작업을 사용하면 크로스탭 업데이트를 수행할 수 있으며, 상위 테이블의 행이 업데이트되면 ON UPDATE SET NULL
작업이 행의 값을 재설정합니다. 하위 테이블에 NULL
값이 있습니다. ON UPDATE NO ACTION
또는 UPDATE RESTRICT
작업은 모든 업데이트를 거부합니다. 🎜🎜🎜🎜MySQL 테이블 외래 키 생성 예🎜🎜以下示例创建一个dbdemo
数据库和两个表:categories
和products
。每个类别都有一个或多个产品,每个产品只属于一个类别。 products
表中的cat_id
字段被定义为具有UPDATE ON CASCADE
和DELETE ON RESTRICT
操作的外键。
CREATE DATABASE IF NOT EXISTS dbdemo; USE dbdemo; CREATE TABLE categories( cat_id int not null auto_increment primary key, cat_name varchar(255) not null, cat_description text ) ENGINE=InnoDB; CREATE TABLE products( prd_id int not null auto_increment primary key, prd_name varchar(355) not null, prd_price decimal, cat_id int not null, FOREIGN KEY fk_cat(cat_id) REFERENCES categories(cat_id) ON UPDATE CASCADE ON DELETE RESTRICT )ENGINE=InnoDB;
MySQL添加外键语法
要将外键添加到现有表中,请使用ALTER TABLE
语句与上述外键定义语法:
ALTER table_name ADD CONSTRAINT constraint_name FOREIGN KEY foreign_key_name(columns) REFERENCES parent_table(columns) ON DELETE action ON UPDATE action;
MySQL添加外键示例
现在,我们添加一个名为vendors
的新表,并更改products
表以包含供应商ID
字段:
USE dbdemo; CREATE TABLE vendors( vdr_id int not null auto_increment primary key, vdr_name varchar(255) )ENGINE=InnoDB; ALTER TABLE products ADD COLUMN vdr_id int not null AFTER cat_id;
要在products
表中添加外键,请使用以下语句:
ALTER TABLE products ADD FOREIGN KEY fk_vendor(vdr_id) REFERENCES vendors(vdr_id) ON DELETE NO ACTION ON UPDATE CASCADE;
现在,products
表有两个外键,一个是引用categories
表,另一个是引用vendors
表。
您还可以使用ALTER TABLE
语句将外键删除,如下语句:
ALTER TABLE table_name DROP FOREIGN KEY constraint_name;
在上面的声明中:
DROP FOREIGN KEY
子句之后。请注意,
constraint_name
是在创建或添加外键到表时指定的约束的名称。 如果省略它,MySQL会为您生成约束名称。
要获取生成的表的约束名称,请使用SHOW CREATE TABLE
语句,如下所示:
SHOW CREATE TABLE table_name;
例如,要查看products
表的外键,请使用以下语句:
SHOW CREATE TABLE products;
以下是语句的输出:
CREATE TABLE products ( prd_id int(11) NOT NULL AUTO_INCREMENT, prd_name varchar(355) NOT NULL, prd_price decimal(10,0) DEFAULT NULL, cat_id int(11) NOT NULL, vdr_id int(11) NOT NULL, PRIMARY KEY (prd_id), KEY fk_cat (cat_id), KEY fk_vendor(vdr_id), CONSTRAINT products_ibfk_2 FOREIGN KEY (vdr_id) REFERENCES vendors (vdr_id) ON DELETE NO ACTION ON UPDATE CASCADE, CONSTRAINT products_ibfk_1 FOREIGN KEY (cat_id) REFERENCES categories (cat_id) ON UPDATE CASCADE ) ENGINE=InnoDB;
products
表有两个外键约束:products_ibfk_1
和products_ibfk_2
。
可以使用以下语句删除products
表的外键:
ALTER TABLE products DROP FOREIGN KEY products_ibfk_1; ALTER TABLE products DROP FOREIGN KEY products_ibfk_2;
有时,因为某种原因需要禁用外键检查(例如将CSV文件中的数据导入表中)非常有用。 如果不禁用外键检查,则必须以正确的顺序加载数据,即必须首先将数据加载到父表中,然后再将数据加载导入到子表中,这可能是乏味的。 但是,如果禁用外键检查,则可以按任何顺序加载导入数据。
除非禁用外键检查,否则不能删除由外键约束引用的表。删除表时,还会删除为表定义的任何约束。
要禁用外键检查,请使用以下语句:
SET foreign_key_checks = 0;
当然,可以使用以下语句启用它:
SET foreign_key_checks = 1;
【相关推荐:mysql视频教程】
위 내용은 mysql의 외래 키는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!