Isih Tersuai dalam Oracle SQL
Apabila memesan data dalam Oracle SQL, ada kalanya pesanan isihan tersuai diperlukan, seperti mengutamakan nilai tertentu untuk muncul di bahagian atas. Satu senario biasa ialah mengutamakan mata wang tertentu, seperti USD, di tengah-tengah campuran mata wang.
Untuk memesan lajur berdasarkan keutamaan tersuai, fungsi CASE atau DECODE boleh digunakan. Begini caranya:
Menggunakan CASE
order by CASE when currency = 'USD' then 1 when currency = 'BHT' then 2 when currency = 'JPY' then 3 when currency = 'MYR' then 4 else 5 END
Dengan memberikan nilai angka kepada setiap mata wang, pengisihan akan mengutamakan USD dengan nilai 1, diikuti oleh BHT (2 ), JPY (3) dan MYR (4). Mana-mana mata wang lain yang tidak dinyatakan akan berada di bawah nilai lalai 5.
Menggunakan DECODE (Oracle-specific)
Sintaks yang lebih ringkas boleh dicapai menggunakan DECODE:
order by DECODE(currency, 'USD', 1, 'BHT', 2, 'JPY', 3, 'MYR', 4, 5)
Alternatif untuk Tidak Disebut Mata Wang
Jika susunan keutamaan perlu memasukkan mata wang yang tidak dinyatakan secara jelas dalam ungkapan CASE/DECODE, pengubahsuaian berikut boleh digunakan:
order by CASE when currency = 'USD' then '001' else currency END
Ini memberikan nilai aksara kepada USD ('001'), memastikan penempatannya di bahagian atas, sambil membiarkan baki mata wang diisih mengikut abjad.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Pengisihan Tersuai dalam Oracle SQL untuk Mengutamakan Nilai Tertentu?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!