cari
Rumahpangkalan datatutorial mysqlBagaimana untuk Mengisih Nilai Bukan Null Menaik, kemudian Nulls, dengan -1 Nilai Terakhir dalam PostgreSQL?

How to Sort Non-Null Values Ascending, then Nulls, with -1 Values Last in PostgreSQL?

Mengisih Nilai Null dengan Cara Istimewa selepas Nilai Bukan Null

Latar Belakang

Dalam jadual PostgreSQL dengan medan isihan pilihan, matlamatnya ialah untuk mengisih nilai seperti berikut:

  • Nilai bukan nol harus datang pertama, mengisih dalam tertib menaik berdasarkan nilai isihannya.
  • Nilai NULL hendaklah datang selepas nilai bukan nol.
  • Secara luar biasa, nilai isihan -1 sepatutnya muncul selepas semua nilai bukan nol yang lain .

Penyelesaian

Untuk mencapai gelagat pengisihan ini, satu pendekatan ialah menggunakan yang berikut URUSAN MENGIKUT klausa:

ORDER BY (sort IS NOT DISTINCT FROM -1), sort

Penjelasan

Klausa ini beroperasi seperti berikut:

  • (isih TIDAK BERBEZA DARI -1) menilai kepada SALAH untuk semua nilai kecuali -1, yang menilai kepada BENAR.
  • Ungkapan diisih dalam menaik tertib, bermakna nilai FALSE (nilai bukan nol selain -1) didahulukan sebelum nilai TRUE (-1).
  • Klausa ORDER BY sekunder kemudian diisih mengikut nilai isihan, memastikan nilai bukan nol diisih dalam tertib menaik dalam kumpulan masing-masing.

Contoh

Pertimbangkan sampel yang disediakan data:

id f_id name sort
1 1 zeta -1
2 1 alpha 1
3 1 gamma 3
4 1 beta 2
5 1 delta NULL
6 1 epsilon NULL

Menggunakan klausa yang disediakan, item akan diisih seperti berikut:

alpha, beta, gamma, delta, epsilon, zeta

Borang Alternatif

Alternatif yang setara dengan klausa awal ialah:

ORDER BY (sort IS DISTINCT FROM -1) DESC, sort

Klausa ini menghasilkan gelagat pengisihan yang sama tetapi menggunakan kata kunci DESC untuk mengisih (isih BERBEZA DARI -1) ungkapan dalam tertib menurun.

Atas ialah kandungan terperinci Bagaimana untuk Mengisih Nilai Bukan Null Menaik, kemudian Nulls, dengan -1 Nilai Terakhir dalam PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
MySQL: Apa set aksara tersedia untuk jenis data rentetan?MySQL: Apa set aksara tersedia untuk jenis data rentetan?May 10, 2025 am 12:07 AM

Mysqloffersvariouscharactersetsforstringdatatypes: 1) Latin1forwesterneuropeanlanguages, 2) UTF8FormultoLuualSupport, 3) UTF8MB4F OrextendedUnicodeincludingemojis, 4) Ucs2forfixed-widthencoding, dan5) asciiforbasiclatin.choosingherightsetensureSureSureSureSureStegrity

MySQL: Streaming gumpalan lebih baik daripada menyimpannya?MySQL: Streaming gumpalan lebih baik daripada menyimpannya?May 10, 2025 am 12:06 AM

Gumpalan streaming memang lebih baik daripada penyimpanan langsung kerana ia mengurangkan penggunaan memori dan meningkatkan prestasi. 1) Dengan secara beransur -ansur membaca dan memproses fail, degradasi prestasi pangkalan data dan prestasi dielakkan. 2) Streaming memerlukan logik kod yang lebih kompleks dan boleh meningkatkan bilangan operasi I/O.

Jenis String Mysql: Penyimpanan, Prestasi, dan Amalan TerbaikJenis String Mysql: Penyimpanan, Prestasi, dan Amalan TerbaikMay 10, 2025 am 12:02 AM

Mysqlstringtypesimpactstorageandperformanceasfollows: 1) che-chexed-length, selingasingthesamestoragespace, whycanbefasterbutlessspace-efficient.2) varcharisvariable-length, morespace-efficientbutpotoTanSlower.3)

Memahami Jenis String MySQL: Varchar, Teks, Char, dan banyak lagiMemahami Jenis String MySQL: Varchar, Teks, Char, dan banyak lagiMay 10, 2025 am 12:02 AM

Mysqlstringtypesincludevarchar, teks, char, enum, andset.1) varcharisversatorvariable-lengtstringsuptoaspecifiedlimit.2)

Apakah jenis data rentetan dalam mysql?Apakah jenis data rentetan dalam mysql?May 10, 2025 am 12:01 AM

Mysqloffersvariousstringdatatypes: 1) charforfixed-lengtstrings, 2) varcharforvariable-lengthtext, 3) binaryandvarbinaryforbinarydata, 4) blobandtextforlargedata, dan5)

Cara Memberi Kebenaran kepada Pengguna MySQL BaruCara Memberi Kebenaran kepada Pengguna MySQL BaruMay 09, 2025 am 12:16 AM

TograntpermissionstonewMySQLusers,followthesesteps:1)AccessMySQLasauserwithsufficientprivileges,2)CreateanewuserwiththeCREATEUSERcommand,3)UsetheGRANTcommandtospecifypermissionslikeSELECT,INSERT,UPDATE,orALLPRIVILEGESonspecificdatabasesortables,and4)

Cara Menambah Pengguna di MySQL: Panduan Langkah demi LangkahCara Menambah Pengguna di MySQL: Panduan Langkah demi LangkahMay 09, 2025 am 12:14 AM

Toaddusersinmysqleffectivelyandsecurely, ikutiTheSesteps: 1) usethecreateUserStatementToadDanewuser, spesifyingthehostandastrongpassword.2) GrantnessaryPrivileGeSingSupingTheGrantement, ADHERINGTOTHEPRINCIPREFLEFLEASE.3)

MySQL: Menambah pengguna baru dengan kebenaran yang kompleksMySQL: Menambah pengguna baru dengan kebenaran yang kompleksMay 09, 2025 am 12:09 AM

TOADDANEWUSERWITHCEPLEXPELPISIONSIONSIONMYSQL, FOLLONGHESESTEPS: 1) COTETETHEUSERWITHCEATEUSER'NEWUSER '@' LOCSOUSTHOST'IDENTIFIFYBY'PA ssword ';. 2) grantrearaccesstoalltablesin'mydatabase'withgrantselectonmydatabase.to'newuser'@'localhost' ;. 3) GrantWriteAccessto '

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Nordhold: Sistem Fusion, dijelaskan
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa