>데이터 베이스 >MySQL 튜토리얼 >mysql의 외래 키는 무엇입니까?

mysql의 외래 키는 무엇입니까?

青灯夜游
青灯夜游원래의
2022-02-17 11:42:4522095검색

MySQL에서 외래 키는 두 테이블의 데이터 간의 연결을 설정하고 강화하는 데 사용되는 하나 이상의 열입니다. 이는 한 테이블의 필드가 다른 테이블의 필드에서 참조된다는 것을 나타냅니다. 외래 키는 관련 테이블의 데이터에 제한을 두어 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 KEYREFERENCES中指定的子表和父表中的列数必须相同。
  • ON DELETE子句允许定义当父表中的记录被删除时,子表的记录怎样执行操作。如果省略ON DELETE子句并删除父表中的记录,则MySQL将拒绝删除子表中相关联的数据。此外,MySQL还提供了一些操作,以便您可以使用其他选项,例如ON DELETE CASCADE,当删除父表中的记录时,MySQL可以删除子表中引用父表中记录的记录。 如果您不希望删除子表中的相关记录,请改用ON DELETE SET NULL操作。当父表中的记录被删除时,MySQL会将子表中的外键列值设置为NULL,条件是子表中的外键列必须接受NULL值。 请注意,如果使用ON DELETE NO ACTIONON DELETE RESTRICT操作,MySQL将拒绝删除。
  • ON UPDATE子句允许指定在父表中的行更新时,子表中的行会怎样执行操作。当父表中的行被更新时,可以省略ON UPDATE子句让MySQL拒绝对子表中的行的任何更新。 ON UPDATE CASCADE操作允许您执行交叉表更新,并且当更新父表中的行时,ON UPDATE SET NULL操作会将子表中行中的值重置为NULL值。 ON UPDATE NO ACTIONUPDATE 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 KEYREFERENCES에 지정된 하위 테이블과 상위 테이블의 열 수가 동일해야 합니다. 🎜🎜 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数据库和两个表:categoriesproducts。每个类别都有一个或多个产品,每个产品只属于一个类别。 products表中的cat_id字段被定义为具有UPDATE ON CASCADEDELETE 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表。

    删除MySQL外键

    您还可以使用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_1products_ibfk_2

    可以使用以下语句删除products表的外键:

    ALTER TABLE products 
    DROP FOREIGN KEY products_ibfk_1;
    
    ALTER TABLE products 
    DROP FOREIGN KEY products_ibfk_2;

    MySQL禁用外键检查

    有时,因为某种原因需要禁用外键检查(例如将CSV文件中的数据导入表中)非常有用。 如果不禁用外键检查,则必须以正确的顺序加载数据,即必须首先将数据加载到父表中,然后再将数据加载导入到子表中,这可能是乏味的。 但是,如果禁用外键检查,则可以按任何顺序加载导入数据。

    除非禁用外键检查,否则不能删除由外键约束引用的表。删除表时,还会删除为表定义的任何约束。

    要禁用外键检查,请使用以下语句:

    SET foreign_key_checks = 0;

    当然,可以使用以下语句启用它:

    SET foreign_key_checks = 1;

    【相关推荐:mysql视频教程

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

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