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