"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment sélectionner efficacement les premières lignes par catégorie dans MySQL sans fonctions analytiques ?

Comment sélectionner efficacement les premières lignes par catégorie dans MySQL sans fonctions analytiques ?

Publié le 2024-11-08
Parcourir:165

How to Efficiently Select Top Rows per Category in MySQL Without Analytic Functions?

Sélection des premières lignes par catégorie dans MySQL

Pour récupérer un nombre limité de lignes de chaque catégorie dans une table, vous pouvez utiliser des fonctions analytiques . Cependant, MySQL ne propose pas directement ces fonctions. Néanmoins, il est possible de les émuler à l'aide de variables.

Émulation de fonctions analytiques

La requête MySQL suivante émule la fonctionnalité des fonctions analytiques pour sélectionner les 3 premières lignes de chaque catégorie. :

SELECT x.*
FROM (
    SELECT t.*,
    CASE 
        WHEN @category != t.category THEN @rownum := 1 
        ELSE @rownum := @rownum   1 
    END AS rank,
    @category := t.category AS var_category
    FROM TBL_ARTIKUJT t
    JOIN (SELECT @rownum := NULL, @category := '') r
    ORDER BY t.category
) x
WHERE x.rank 

Explication

  • La sous-requête sélectionne toutes les lignes de la table TBL_ARTIKUJT et initialise deux variables de session, @rownum et @category, pour suivre le classement et la catégorie actuels.
  • le classement attribué à chaque ligne indique sa position dans sa catégorie. Lorsqu'une nouvelle catégorie est rencontrée, le classement est réinitialisé à 1.
  • var_category est utilisé pour stocker la catégorie pour chaque ligne.
  • L'instruction SELECT externe filtre la sous-requête, en sélectionnant uniquement les lignes avec un rang. inférieur ou égal à 3.

Cette méthode vous permet d'implémenter la fonctionnalité souhaitée sans recourir à des fonctions analytiques, qui ne sont pas prises en charge par MySQL.

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3