Maison > base de données > tutoriel mysql > Comment sélectionner des identifiants MySQL avec plusieurs valeurs de colonne spécifiques sur les lignes ?

Comment sélectionner des identifiants MySQL avec plusieurs valeurs de colonne spécifiques sur les lignes ?

Mary-Kate Olsen
Libérer: 2024-10-30 07:30:27
original
743 Les gens l'ont consulté

How to Select MySQL IDs with Multiple Specific Column Values Across Rows?

Sélection des identifiants MySQL apparaissant sur plusieurs lignes avec des valeurs de colonne spécifiques

L'identification des éléments qui satisfont à deux ou plusieurs valeurs spécifiques dans une colonne spécifique peut être difficile dans MySQL. Considérez la structure de tableau suivante :

+-----------------------+
| item_id | category_id |
+-----------------------+
|   1     |    200      |
|   1     |    201      |
|   1     |    202      |
|   2     |    201      |
|   2     |    202      |
|   3     |    202      |
|   3     |    203      |
|   4     |    201      |
|   4     |    207      |
+-----------------------+
Copier après la connexion

L'objectif est de sélectionner uniquement les éléments qui appartiennent aux deux catégories désignées, bien qu'ils soient potentiellement associés à des catégories supplémentaires.

Solutions inefficaces :

  • WHEREcategory_id = 201 ANDcategory_id = 202 :Échec car il recherche des conditions impossibles (deux valeurs sur une seule ligne).
  • WHEREcategory_id = 201 OUcategory_id = 202 :Renvoie des résultats incorrects (inclut les éléments qui n'appartiennent pas aux deux catégories).

Solutions efficaces :

Auto-jointure :

SELECT c1.item_id
FROM item_category AS c1
INNER JOIN item_category AS c2 ON c1.item_id = c2.item_id
WHERE c1.category_id = 201 AND c2.category_id = 202
Copier après la connexion

Cette méthode joint les lignes de la même table en fonction d'une colonne commune (item_id), permettant des comparaisons entre plusieurs lignes et leurs valeurs.

GROUP BY :

SELECT c.item_id, COUNT(*) AS cat_count
FROM item_category AS c
WHERE c.category_id IN (201,202)
GROUP BY c.item_id
HAVING cat_count = 2
Copier après la connexion

En utilisant la fonction GROUP BY, cette approche compte le nombre de valeurs de catégorie distinctes pour chaque item_id. Les éléments avec un cat_count égal au nombre de catégories spécifiées (2 dans ce cas) sont sélectionnés.

Conclusion :

Les deux méthodes identifient efficacement les éléments qui répondent aux critères souhaités . Le choix entre eux dépend des exigences spécifiques et des considérations de performances de la base de données.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal