Lorsque l'on traite plusieurs tables, il peut être nécessaire de sélectionner plusieurs colonnes dans une sous-requête. Cependant, de simples jointures peuvent ne pas donner le résultat souhaité lorsqu'il manque des enregistrements dans la sous-table.
La clé pour résoudre ce problème réside dans la compréhension que les tables peuvent être dérivées des deux tables physiques. et sous-requêtes. En tirant parti de ce concept, il devient possible de récupérer plusieurs colonnes à partir d'une seule sous-requête.
Considérons l'exemple suivant :
SELECT a.attr, b.id, b.trans, b.lang FROM attribute a JOIN ( SELECT at.id AS id, at.translation AS trans, at.language AS lang, a.attribute FROM attributeTranslation at ) b ON (a.id = b.attribute AND b.lang = 1)
Dans cet exemple, la sous-requête génère une table virtuelle b qui contient les colonnes souhaitées. En joignant cette table virtuelle à la table principale a, nous pouvons récupérer toutes les données nécessaires en une seule requête.
Cette technique peut être étendue pour inclure des tables récapitulatives ou de regroupement . Par exemple, la requête suivante génère une table virtuelle c avec un nombre de traductions pour chaque attribut :
SELECT a.attr, b.id, b.trans, b.lang, c.langcount FROM attribute a JOIN ( SELECT at.id AS id, at.translation AS trans, at.language AS lang, at.attribute FROM attributeTranslation at ) b ON (a.id = b.attribute AND b.lang = 1) JOIN ( SELECT count(*) AS langcount, at.attribute FROM attributeTranslation at GROUP BY at.attribute ) c ON (a.id = c.attribute)
Cette requête renvoie les colonnes souhaitées ainsi que le nombre de traductions pour chaque attribut.
Bien que cette technique offre de la flexibilité, la performance doit être prise en compte. Les optimiseurs MySQL sont capables de fusionner des sous-requêtes similaires, mais il est recommandé d'éviter une utilisation excessive des sous-requêtes et d'optimiser les requêtes pour plus d'efficacité. Rejoindre plusieurs tables peut être une option plus efficace dans certains scénarios.
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!