suchen
HeimBackend-EntwicklungPython-TutorialWie gruppiere ich Daten mithilfe der Querysets von Django?

How to Group Data Using Django's Querysets?

Gruppieren von Daten in Django-Abfragen

In Django erfordert das Abrufen von Daten aus der Datenbank häufig die Verwendung von Abfragesätzen. Diese Abfragesätze bieten verschiedene Methoden zum Filtern, Sortieren und Bearbeiten von Daten. Eine häufige Operation ist das Gruppieren von Daten nach einem bestimmten Feld, ähnlich der SQL-GROUP BY-Klausel.

Aggregation für die Gruppierung

Um Daten in Django zu gruppieren, kann man die Aggregationsfunktionen des ORM nutzen. Betrachten Sie beispielsweise die folgende Abfrage, die alle Mitglieder abruft:

Members.objects.all()

Diese Abfrage gibt eine Liste von Tupeln zurück, wobei jedes Tupel die Details eines Mitglieds darstellt:

[('Eric', 'Salesman', 'X-Shop'),
 ('Freddie', 'Manager', 'X2-Shop'),
 ('Teddy', 'Salesman', 'X2-Shop'),
 ('Sean', 'Manager', 'X2-Shop')]

Um diese Ergebnisse zu gruppieren Im Bezeichnungsfeld kann man die Methoden „values()“ und „annotate()“ verwenden:

from django.db.models import Count

result = (
    Members.objects
    .values('designation')
    .annotate(dcount=Count('designation'))
    .order_by()
)

Diese Abfrage generiert eine ähnliche SQL-Anweisung zu:

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

Das Ergebnis ist eine Liste von Wörterbüchern, die jeweils eine Bezeichnung und die Anzahl der Mitglieder für diese Bezeichnung darstellen:

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

Um mehrere Felder in die Ergebnisse einzuschließen, einfach Fügen Sie sie als Argumente zur Methode „values()“ hinzu, wie hier gezeigt:

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

Referenzen

Weitere Informationen zur Aggregation und Gruppierung in Django finden Sie in den folgenden Ressourcen:

  • Django-Dokumentation: [Werte](https://docs.djangoproject.com/en/stable/ref/models/querysets/#values) , [Annotieren](https://docs.djangoproject.com/en/stable/ref/models/querysets/#annotate), [Anzahl](https://docs.djangoproject.com/en/stable/ref/models/querysets/#django.db.models.Count)
  • Django-Dokumentation: [Aggregation](https:// docs.djangoproject.com/en/stable/topics/db/aggregation/), insbesondere der Abschnitt über [Interaktion mit Standardreihenfolge oder order_by()](https://docs.djangoproject.com/en/stable/topics/db/aggregation/#interaction-with-default-ordering-or-orderby)

Das obige ist der detaillierte Inhalt vonWie gruppiere ich Daten mithilfe der Querysets von Django?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Pythons Hybridansatz: Zusammenstellung und Interpretation kombiniertPythons Hybridansatz: Zusammenstellung und Interpretation kombiniertMay 08, 2025 am 12:16 AM

Pythonusesahybridapproach, kombinierte CompilationTobyteCodeAnDinterpretation.1) codiscompiledtoplatform-unintenpendentBytecode.2) BytecodeIsinterpretedBythepythonvirtualMachine, EnhancingEfficiency und Portablabilität.

Erfahren Sie die Unterschiede zwischen Pythons 'für' und 'while the' LoopsErfahren Sie die Unterschiede zwischen Pythons 'für' und 'while the' LoopsMay 08, 2025 am 12:11 AM

Die Keedifferzences -zwischen Pythons "für" und "während" Loopsare: 1) "für" LoopsareideAlForiteratingOvercesorknownowniterations, während 2) "LoopsarebetterForContiningUtilAconditionismethoutnredefineditInations.un

Python verkettet Listen mit DuplikatenPython verkettet Listen mit DuplikatenMay 08, 2025 am 12:09 AM

In Python können Sie Listen anschließen und doppelte Elemente mit einer Vielzahl von Methoden verwalten: 1) Verwenden von Operatoren oder erweitert (), um alle doppelten Elemente beizubehalten; 2) Konvertieren in Sets und kehren Sie dann zu Listen zurück, um alle doppelten Elemente zu entfernen. Die ursprüngliche Bestellung geht jedoch verloren. 3) Verwenden Sie Schleifen oder listen Sie Verständnisse auf, um Sätze zu kombinieren, um doppelte Elemente zu entfernen und die ursprüngliche Reihenfolge zu verwalten.

Python List -Verkettungsleistung: GeschwindigkeitsvergleichPython List -Verkettungsleistung: GeschwindigkeitsvergleichMay 08, 2025 am 12:09 AM

THESTESTMETHODFORLISTCONCATENATIONINPYTHONDSONLISTSIZE: 1) ForsmallLists, The Operatoriseffiction.2) Forlargerlists, list.extend () orlistCompretInsisfaster, WithEttend () MORMOREMEIMIENTIENTIENTYMODIFICIENTLISTLISTERSIN-SPACE.

Wie setzen Sie Elemente in eine Python -Liste ein?Wie setzen Sie Elemente in eine Python -Liste ein?May 08, 2025 am 12:07 AM

ToInsertElementsIntoapherthonList, useAppend () toaddtotheend, insert () foraspecificposition und fortend () formulpulpulements.1) useeAppend () Foraddingsingleiitemstotheend.2) useInsert () toaddataspecificIndex, zwarsititithulsForlargerists

Sind Python -Listen dynamische Arrays oder verknüpfte Listen unter der Haube?Sind Python -Listen dynamische Arrays oder verknüpfte Listen unter der Haube?May 07, 2025 am 12:16 AM

PythonlistsarEmplementedasdynamicArrays, Notlinkedlists.1) Sie haben incontuituousMemoryblocks, die ausgelöst werden, wobei die Auswirkungen auf die Erfüllung von Zeitungen/Deletionsbutionen, die in Verbindung gebracht wurden

Wie entfernen Sie Elemente aus einer Python -Liste?Wie entfernen Sie Elemente aus einer Python -Liste?May 07, 2025 am 12:15 AM

PythonoffersfourmainMethodstoremoveLements Fromalist: 1) Entfernen (Wert) removesthefirstoccurceofavalue, 2) Pop (index) removesandreturnsanelementataspecifiedIndex, 3) DelstatementRemovesElementsbyIntexors und 4) clear () removesallitems

Was sollten Sie überprüfen, wenn Sie einen Fehler 'Erlaubnis abgelehnt' erhalten, wenn Sie versuchen, ein Skript auszuführen?Was sollten Sie überprüfen, wenn Sie einen Fehler 'Erlaubnis abgelehnt' erhalten, wenn Sie versuchen, ein Skript auszuführen?May 07, 2025 am 12:12 AM

ToreSolvea "Berechtigte" FehlerwherunningAscript, folgen von THESESTEPS: 1) checkandadjustThescript'SPERMISSIONSCHMOD XMYSCRIPT.SHTOMAKEPEXEx.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

SublimeText3 Englische Version

SublimeText3 Englische Version

Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor