Relations d'auto-référencement en SQL
Dans un schéma de base de données, il est possible que deux tables se référencent mutuellement. Cependant, il est important de considérer les conséquences de telles relations d'auto-référencement.
Comme l'illustre la conception du tableau fourni, les tableaux products et products_pictures forment une référence circulaire : products.DEFAULT_PICTURE_ID fait référence à products_pictures.ID et products_pictures. .PRODUCT_ID référence products.ID.
Circularité Préoccupations
Les références circulaires entre les tables peuvent introduire de la complexité et des problèmes potentiels :
Options d'atténuation
Pour éviter les inconvénients des références circulaires, envisagez les options suivantes :
Option 1 : Nullable Foreign Clé
Rendre l'une des colonnes de clé étrangère nullable. Cela permet de créer des enregistrements dans une table sans avoir à créer au préalable des enregistrements dans la table associée, résolvant ainsi le problème de la poule et de l'œuf. Cependant, des contraintes supplémentaires sont nécessaires pour éviter les relations invalides, comme le démontre l'exemple fourni.
Option 2 : IsDefault Indicator
Remplacez la clé étrangère dans la table des produits par une colonne booléenne IsDefault dans la table products_pictures. Cette approche nécessite une contrainte supplémentaire au niveau de la table pour garantir qu'une seule image par produit peut être désignée par défaut. MySQL, cependant, ne prend pas en charge de telles contraintes d'indexation partielle.
Option 3 : Contraintes reportables
Cette option implique de différer l'application des contraintes de clé étrangère jusqu'après l'insertion des données. Bien que certains SGBD prennent en charge cela, cela n'est pas disponible dans MySQL.
Option 4 : Table de jointure supplémentaire
Introduire une table de jointure distincte pour établir la relation entre les produits et tableaux products_pictures. Cela élimine la référence circulaire et permet de déclarer les clés étrangères comme non nulles.
Résumé pour MySQL
Parmi les options discutées, MySQL prend en charge les deux suivantes :
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!