Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Memesan Keputusan Pertanyaan Django dengan NULLS LAST dalam PostgreSQL?

Bagaimana untuk Memesan Keputusan Pertanyaan Django dengan NULLS LAST dalam PostgreSQL?

Linda Hamilton
Lepaskan: 2024-12-30 22:32:11
asal
768 orang telah melayarinya

How to Order Django Query Results with NULLS LAST in PostgreSQL?

Memesan Keputusan Pertanyaan dengan "NULLS LAST" dalam Django

Apabila bekerja dengan PostgreSQL, anda mungkin menghadapi senario di mana anda ingin mengisih model keputusan mengutamakan nilai bukan nol berbanding null menggunakan "NULLS LAST" pilihan.

Percubaan dan Isu

Pendekatan awal menggunakan tambahan(order_by=('-price', 'NULLS LAST')) boleh mengakibatkan ralat, " Tidak dapat menyelesaikan kata kunci 'NULLS LAST' ke dalam medan."

Penyelesaian

Untuk mencapai gelagat pengisihan yang diingini, gunakan penyelesaian berikut yang diperkenalkan dalam Django 1.11:

from django.db.models import F
MyModel.objects.all().order_by(F('price').desc(nulls_last=True))
Salin selepas log masuk

Sintaks ini menggunakan ungkapan F yang disediakan oleh Django, membolehkan anda menentukan pengisihan medan dengan parameter yang boleh disesuaikan. Argumen desc(nulls_last=True) memastikan bahawa nilai nol dianggap sebagai elemen terakhir dalam hasil yang diisih.

Rujukan

Untuk maklumat lanjut, rujuk rasmi Dokumentasi Django untuk versi 1.11 dan 3.1:

  • Django 1.11: https://docs.djangoproject.com/en/dev/releases/1.11/#expression-asc-and-desc-nulls-first-and-nulls-last-parameters
  • Django 3.1: https://docs.djangoproject.com/en/3.1/ref/models/expressions/#using-f-to-sort-null-values

Atas ialah kandungan terperinci Bagaimana untuk Memesan Keputusan Pertanyaan Django dengan NULLS LAST dalam PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan