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
Libérer: 2024-12-11 02:22:09
original
664 Les gens l'ont consulté

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()
)
Copier après la connexion

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

SELECT designation, COUNT(designation) AS dcount
FROM members GROUP BY designation
Copier après la connexion

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}]
Copier après la connexion

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

    .values('designation', 'first_name', 'last_name')
Copier après la connexion

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!

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