Maison > base de données > tutoriel mysql > qu'est-ce qu'une clé étrangère dans MySQL

qu'est-ce qu'une clé étrangère dans MySQL

青灯夜游
Libérer: 2022-02-17 16:04:19
original
22125 Les gens l'ont consulté

Dans MySQL, une clé étrangère est une ou plusieurs colonnes utilisées pour établir et renforcer le lien entre les données de deux tables. Cela signifie qu'un champ d'une table est référencé par un champ d'une autre table. Les clés étrangères imposent des restrictions sur les données des tables associées, permettant à MySQL de maintenir l'intégrité référentielle.

qu'est-ce qu'une clé étrangère dans MySQL

L'environnement d'exploitation de ce tutoriel : système windows7, version mysql8, ordinateur Dell G3.

Les clés étrangères sont relatives aux clés primaires.

Clé primaire Un attribut ou un groupe d'attributs qui identifie de manière unique une ligne du tableau. Une table ne peut avoir qu’une seule clé primaire, mais peut avoir plusieurs index candidats. Les clés primaires forment souvent des contraintes d'intégrité référentielle avec les clés étrangères pour éviter les incohérences des données. La clé primaire peut garantir que l'enregistrement est unique et que le champ de clé primaire n'est pas vide. Le système de gestion de base de données génère automatiquement un index unique pour la clé primaire, de sorte que la clé primaire est également un index spécial.

Une clé étrangère est une ou plusieurs colonnes utilisées pour établir et renforcer le lien entre les données de deux tables. Une clé étrangère signifie qu'un champ d'une table est référencé par un champ d'une autre table. Les clés étrangères imposent des restrictions sur les données des tables associées, permettant à MySQL de maintenir l'intégrité référentielle.

Les contraintes de clés étrangères sont principalement utilisées pour maintenir la cohérence des données entre deux tables. En bref, la clé étrangère d'une table est la clé primaire d'une autre table, et la clé étrangère relie les deux tables. Dans des circonstances normales, pour supprimer la clé primaire d'une table, vous devez d'abord vous assurer qu'il n'existe pas de clé étrangère identique dans d'autres tables (c'est-à-dire qu'aucune clé étrangère n'est associée à la clé primaire de la table).

Lors de la définition des clés étrangères, vous devez respecter les règles suivantes :

  • La table principale doit déjà exister dans la base de données, ou être la table en cours de création. Si c'est le dernier cas, la table maître et la table esclave sont la même table. Une telle table est appelée table auto-référentielle, et cette structure est appelée intégrité auto-référentielle.

  • Doit définir une clé primaire pour la table principale.

  • Les clés primaires ne peuvent pas contenir de valeurs nulles, mais les valeurs nulles sont autorisées dans les clés étrangères. Autrement dit, tant que chaque valeur non nulle de la clé étrangère apparaît dans la clé primaire spécifiée, le contenu de la clé étrangère est correct.

  • Spécifiez le nom de la colonne ou une combinaison de noms de colonnes après le nom de la table principale. Cette colonne ou combinaison de colonnes doit être la clé primaire ou la clé candidate de la table principale.

  • Le nombre de colonnes dans la clé étrangère doit être le même que le nombre de colonnes dans la clé primaire de la table principale.

  • Le type de données de la colonne dans la clé étrangère doit être le même que le type de données de la colonne correspondante dans la clé primaire de la table principale.

Créer une clé étrangère

Syntaxe de création de clé étrangère MySQL

La syntaxe suivante illustre comment définir une clé étrangère dans une sous-table dans une instruction CREATE TABLE. CREATE TABLE语句中的子表中定义外键。

CONSTRAINT constraint_name
FOREIGN KEY foreign_key_name (columns)
REFERENCES parent_table(columns)
ON DELETE action
ON UPDATE action
Copier après la connexion

下面我们来更详细的查看上面语法:

  • 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;
    Copier après la connexion
    Copier après la connexion
  • Regardons la syntaxe ci-dessus plus en détail :

    La clause CONSTRAINT vous permet de définir des noms de contraintes pour les contraintes de clé étrangère. Si vous l'omettez, MySQL générera automatiquement un nom. La clause FOREIGN KEY spécifie les colonnes de la table enfant qui font référence aux colonnes de clé primaire de la table parent. Vous pouvez placer un nom de clé étrangère après la clause FOREIGN KEY, ou laisser MySQL créer un nom pour vous. Notez que MySQL crée automatiquement un index avec le nom étranger_key_name.

    🎜La clause REFERENCES spécifie les références aux colonnes de la table parent et de ses tables enfants. Le nombre de colonnes dans les tables enfant et parent spécifié dans FOREIGN KEY et REFERENCES doit être le même. 🎜🎜La clause ON DELETE vous permet de définir comment les enregistrements de la table enfant effectuent les opérations lorsque les enregistrements de la table parent sont supprimés. Si vous omettez la clause ON DELETE et supprimez les enregistrements de la table parent, MySQL refusera de supprimer les données associées dans la table enfant. De plus, MySQL fournit également certaines opérations afin que vous puissiez utiliser des options supplémentaires, telles que 🎜ON DELETE CASCADE🎜, lors de la suppression d'enregistrements dans la table parent, MySQL peut supprimer les enregistrements de la table enfant qui font référence aux enregistrements de la table parent. Si vous ne souhaitez pas supprimer les enregistrements associés dans la table enfant, utilisez plutôt l'opération ON DELETE SET NULL. Lorsqu'un enregistrement de la table parent est supprimé, MySQL définira la valeur de la colonne de clé étrangère dans la table enfant sur NULL, à condition que la colonne de clé étrangère dans la table enfant doive accepter NULL</ code> >valeur. Veuillez noter que MySQL rejettera la suppression si l'opération <code>ON DELETE NO ACTION ou ON DELETE RESTRICT est utilisée. 🎜🎜La clause ON UPDATE vous permet de spécifier ce qui arrive aux lignes de la table enfant lorsque les lignes de la table parent sont mises à jour. Vous pouvez omettre la clause ON UPDATE pour que MySQL rejette toute mise à jour des lignes de la table enfant lorsque les lignes de la table parent sont mises à jour. L'opération ON UPDATE CASCADE vous permet d'effectuer une mise à jour du tableau croisé, et lorsqu'une ligne de la table parent est mise à jour, l'opération ON UPDATE SET NULL réinitialise la valeur de la ligne. dans la table enfant se trouve une valeur NULL. L'action ON UPDATE NO ACTION ou UPDATE RESTRICT rejette toute mise à jour. 🎜🎜🎜🎜Exemple MySQL de création de clé étrangère de table🎜🎜

    以下示例创建一个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;
    Copier après la connexion
    Copier après la connexion

    添加外键

    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;
    Copier après la connexion

    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;
    Copier après la connexion

    要在products表中添加外键,请使用以下语句:

    ALTER TABLE products
    ADD FOREIGN KEY fk_vendor(vdr_id)
    REFERENCES vendors(vdr_id)
    ON DELETE NO ACTION
    ON UPDATE CASCADE;
    Copier après la connexion

    现在,products表有两个外键,一个是引用categories表,另一个是引用vendors表。

    删除MySQL外键

    您还可以使用ALTER TABLE语句将外键删除,如下语句:

    ALTER TABLE table_name 
    DROP FOREIGN KEY constraint_name;
    Copier après la connexion

    在上面的声明中:

    • 首先,指定要从中删除外键的表名称。
    • 其次,将约束名称放在DROP FOREIGN KEY子句之后。

    请注意,constraint_name是在创建或添加外键到表时指定的约束的名称。 如果省略它,MySQL会为您生成约束名称。

    要获取生成的表的约束名称,请使用SHOW CREATE TABLE语句,如下所示:

    SHOW CREATE TABLE table_name;
    Copier après la connexion

    例如,要查看products表的外键,请使用以下语句:

    SHOW CREATE TABLE products;
    Copier après la connexion

    以下是语句的输出:

    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;
    Copier après la connexion

    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;
    Copier après la connexion

    MySQL禁用外键检查

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

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

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

    SET foreign_key_checks = 0;
    Copier après la connexion

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

    SET foreign_key_checks = 1;
    Copier après la connexion

    【相关推荐:mysql视频教程

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers numéros
MySQL arrête le processus
Depuis 1970-01-01 08:00:00
0
0
0
Env中mysql
Depuis 1970-01-01 08:00:00
0
0
0
Erreur lors de l'installation de MySQL sous Linux
Depuis 1970-01-01 08:00:00
0
0
0
php - problème de surveillance MySQL
Depuis 1970-01-01 08:00:00
0
0
0
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal