Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Melaksanakan Pengisihan Tersuai dalam Oracle SQL untuk Mengutamakan Nilai Tertentu?

Bagaimanakah Saya Boleh Melaksanakan Pengisihan Tersuai dalam Oracle SQL untuk Mengutamakan Nilai Tertentu?

Mary-Kate Olsen
Lepaskan: 2024-12-27 03:12:08
asal
366 orang telah melayarinya

How Can I Implement Custom Sorting in Oracle SQL to Prioritize Specific Values?

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
Salin selepas log masuk

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)
Salin selepas log masuk

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
Salin selepas log masuk

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!

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