Maison >base de données >tutoriel mysql >Comment sélectionner plusieurs colonnes à partir d'une seule sous-requête dans MySQL ?

Comment sélectionner plusieurs colonnes à partir d'une seule sous-requête dans MySQL ?

Linda Hamilton
Linda Hamiltonoriginal
2024-10-26 22:43:02395parcourir

How to Select Multiple Columns from a Single Subquery in MySQL?

Sélection de plusieurs colonnes à partir d'une seule sous-requête dans MySQL

Problème

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.

Solution

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.

Extension de la technique

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.

Considérations relatives aux performances

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!

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