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 :
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!