Clé étrangère

Un article de Wikipédia, l'encyclopédie libre.

Une clé étrangère, dans une base de données relationnelle, est une contrainte qui garantit l'intégrité référentielle entre deux tables.

Une clé étrangère identifie une colonne ou un ensemble de colonnes d'une table comme référençant une colonne ou un ensemble de colonnes d'une autre table (la table référencée). Les colonnes de la table référencée doivent faire partie d'une contrainte de clé primaire ou d'une contrainte d'unicité. La contrainte de clé étrangère garantit que les valeurs de chaque ligne de la table référençant existent dans la table référencée : ainsi une ligne de la table référençant ne peut pas contenir un ensemble de valeurs qui n'existe pas dans la table référencée.

Une contrainte de clé étrangère permet ainsi de garantir le lien entre plusieurs tables, la création du lien se faisant dès lors que le champ existe (la clef étrangère) sans contrainte de clef étrangère : il s'agit d'un des principes fondamentaux des bases de données relationnelles.

Exemple[modifier | modifier le code]

Soit une base de données, composée de deux tables : la table objet qui contient une liste d'objets d'un inventaire, et la table categorie, qui contient les catégories d'objet :

objet (id_objet, id_categorie, nom_objet)
categorie (id_categorie, nom_categorie)

En définissant des clés primaires sur les colonnes id_objet de la table objet et id_categorie de la table categorie et une clé étrangère sur la colonne id_categorie de la table objet référençant la colonne id_categorie de la table categorie :

  • on ne peut pas insérer une ligne dans la table objet avec un id de catégorie qui n'existe pas dans la table categorie ;
  • on ne peut pas supprimer une ligne de la table categorie si au moins une ligne de la table objet a une valeur d'id de catégorie correspondant à la ligne à supprimer.

Prise en charge[modifier | modifier le code]

La contrainte de clé étrangère est gérée par la plupart des bases de données : Oracle, Microsoft SQL Server, PostgreSQL, MariaDB, etc.

Sur MySQL, il faut utiliser le moteur InnoDB pour obtenir cette fonctionnalité. Actuellement le moteur MyISAM ne gère pas les clés étrangères[1].

Voir aussi[modifier | modifier le code]

Sur les autres projets Wikimedia :

Notes et références[modifier | modifier le code]