Maison >base de données >tutoriel mysql >Pourquoi ma jointure externe gauche échoue-t-elle lors de l'ajout de paramètres de date à la clause WHERE ?
Dépannage d'un LEFT OUTER JOIN avec des filtres de date
Cette requête SQL utilise un LEFT OUTER JOIN sur trois tables : salesrep
, prescriber
et prescriptions
. L'objectif est de récupérer toutes les données de salesrep
, même s'il n'y a aucune entrée correspondante dans prescriber
ou prescriptions
. Le problème survient lorsque des paramètres de date sont ajoutés à la clause WHERE
. Au lieu de renvoyer toutes les salesrep
données comme prévu, la requête renvoie uniquement les résultats pour lesquels des correspondances existent dans les trois tables.
Le problème vient du filtrage sur prescriptions.filldate
dans la clause WHERE
. Cette condition transforme efficacement le LEFT OUTER JOIN en un INNER JOIN pour les salesrep
entrées dépourvues de données prescriptions
correspondantes, car la clause WHERE
élimine les lignes avec des valeurs NULL
pour prescriptions.filldate
.
La solution : déplacer les filtres de date vers la condition JOIN
L'approche correcte consiste à déplacer les contraintes de date de la clause WHERE
vers la clause ON
du LEFT OUTER JOIN entre prescriber
et prescriptions
. Cela garantit que le filtrage des dates n'affecte que la jointure entre ces deux tables, tout en préservant le comportement prévu du LEFT OUTER JOIN par rapport à salesrep
.
La jointure corrigée devrait ressembler à ceci :
<code class="language-sql">LEFT OUTER JOIN prescriptions ON prescriber.dea_no = prescriptions.dea_no AND prescriptions.filldate >= '09-01-12' AND prescriptions.filldate <= '09-17-12'</code>
En plaçant les restrictions de date dans la clause ON
, les lignes de salesrep
seront incluses dans les résultats même s'il n'y a aucune entrée correspondante dans prescriptions
qui satisfait aux critères de date. Ces lignes auront simplement des valeurs NULL
pour les colonnes de prescriber
et prescriptions
. Cela reflète avec précision le comportement souhaité d'un LEFT OUTER JOIN.
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!