Maison >développement back-end >Tutoriel Python >Comment effectuer des requêtes GROUP BY dans Django ?

Comment effectuer des requêtes GROUP BY dans Django ?

Patricia Arquette
Patricia Arquetteoriginal
2024-12-11 02:22:09594parcourir

How to Perform GROUP BY Queries in Django?

Comment réaliser un groupe par requête dans Django ?

Dans Django, pour effectuer un groupe par requête sur un modèle, on peut utiliser le fonctionnalités d’agrégation de l’ORM. Ceci est réalisé en utilisant les méthodes values() et annotate().

Considérons l'exemple suivant :

from django.db.models import Count
result = (Members.objects
    .values('designation')
    .annotate(dcount=Count('designation'))
    .order_by()
)

Ce code se traduit par une requête SQL similaire à :

SELECT designation, COUNT(designation) AS dcount
FROM members GROUP BY designation

Le résultat de la requête sera une liste d'objets dictionnaire, chacun représentant un groupe. Par exemple :

[{'designation': 'Salesman', 'dcount': 2}, 
 {'designation': 'Manager', 'dcount': 2}]

Pour inclure plusieurs champs dans les résultats, ajoutez-les simplement comme arguments aux valeurs() :

    .values('designation', 'first_name', 'last_name')

Références :

  • Documentation Django : valeurs(), annotate() et Count
  • Documentation Django : Agrégation, en particulier la section sur l'interaction avec la commande par défaut ou order_by()

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