Connexion de plusieurs tables SQL via des identifiants partagés
La gestion de bases de données relationnelles nécessite souvent de joindre plusieurs tables en fonction d'ID partagés. Illustrons avec quatre tableaux :
<code>TableA: aID | nameA | dID TableB: bID | nameB | cID | aID TableC: cID | nameC | date TableD: dID | nameD</code>
La jointure initiale
Le processus commence par identifier les relations de clé primaire et étrangère. Ici, TableA
et TableB
se connectent via aID
(clé étrangère dans TableB
), et TableB
et TableC
se connectent via cID
(clé étrangère dans TableB
). Cette jointure initiale ressemble à ceci :
<code class="language-sql">SELECT * FROM TableB INNER JOIN TableA ON TableB.aID = TableA.aID INNER JOIN TableC ON TableB.cID = TableC.cID WHERE DATE(TableC.date) = DATE(NOW());</code>
Intégrer TableD
Pour inclure TableD
, nous ajoutons une autre clause JOIN
liant TableA
et TableD
en utilisant dID
. L'instruction SQL améliorée est :
<code class="language-sql">SELECT * FROM TableA JOIN TableB ON TableB.aID = TableA.aID JOIN TableC ON TableB.cID = TableC.cID JOIN TableD ON TableD.dID = TableA.dID WHERE DATE(TableC.date) = DATE(NOW());</code>
Améliorations clés :
JOIN
distinctes.Cette approche révisée relie efficacement les quatre tableaux, offrant une solution plus propre et plus compréhensible.
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!