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 ?

Pourquoi ma jointure externe gauche échoue-t-elle lors de l'ajout de paramètres de date à la clause WHERE ?

Linda Hamilton
Linda Hamiltonoriginal
2025-01-17 14:16:10609parcourir

Why Does My Left Outer Join Fail When Adding Date Parameters to the WHERE Clause?

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!

Déclaration:
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