Heim > Datenbank > MySQL-Tutorial > Wie sortiere ich NULL-Werte in Django-Abfragen mit PostgreSQL zuletzt?

Wie sortiere ich NULL-Werte in Django-Abfragen mit PostgreSQL zuletzt?

Susan Sarandon
Freigeben: 2024-12-29 14:19:18
Original
379 Leute haben es durchsucht

How to Sort NULL Values Last in Django Queries with PostgreSQL?

So fügen Sie „NULLS LAST“ zu einer Django-Abfrage hinzu

Beim Sortieren von Daten in PostgreSQL ist es üblich, „NULLS“ zu verwenden LAST“-Option, um sicherzustellen, dass Nullwerte am Ende der Ergebnisse sortiert werden. Diese Option wird in der Abfrage-API von Django nicht direkt unterstützt.

Lösung

Der Parameter nulls_last=True kann mit Expression.desc() verwendet werden, um die Reihenfolge von Null zu steuern Werte. Hier ist ein Beispiel:

from django.db.models import F

MyModel.objects.all().order_by(F('price').desc(nulls_last=True))
Nach dem Login kopieren

Diese Syntax ist seit Django 1.11 verfügbar.

Zusätzliche Informationen

Die Dokumente empfehlen die Verwendung von Expression.asc( ) oder Expression.desc() mit dem entsprechenden nulls_last-Parameter anstelle von extra() mit dem alten order_by Syntax.

Für Django 3.1 und höher finden Sie weitere Informationen in der offiziellen Dokumentation:

https://docs.djangoproject.com/en/3.1/ref/models/expressions/# using-f-to-sort-null-values

Das obige ist der detaillierte Inhalt vonWie sortiere ich NULL-Werte in Django-Abfragen mit PostgreSQL zuletzt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage