Bagaimana Mengisih Keputusan MySQL mengikut Pesanan yang Ditentukan dalam Klausa IN()?

Mary-Kate Olsen
Lepaskan: 2024-11-12 17:28:01
asal
696 orang telah melayarinya

How to Sort MySQL Results by the Order Specified in the IN() Clause?

MySQL: Mengisih Keputusan mengikut Susunan Spesifikasi IN()

Apabila mendapatkan semula data dengan klausa IN(), mengekalkan susunan di mana nilai yang ditentukan boleh meningkatkan kebolehbacaan dan kebolehgunaan output. Artikel ini meneroka penyelesaian untuk mengisih hasil berdasarkan jujukan nilai dalam fungsi IN().

Pertimbangkan pertanyaan berikut:

SELECT id, name FROM mytable WHERE name IN ('B', 'A', 'D', 'E', 'C');
Salin selepas log masuk

Pertanyaan ini mengembalikan output berikut, di mana susunan baris tidak konsisten dengan susunan dalam klausa IN():

| id | nama |
^--------^---------^
| 5 | B |
| 6 | B |
| 1 | D |
| 15 | E |
| 17 | E |
| 9 | C |
| 18 | C |

Untuk mengisih hasil dalam susunan yang dinyatakan dalam klausa IN(), kita boleh menggunakan fungsi FIELD. Fungsi FIELD mengambil nilai sebagai argumen pertamanya dan mengembalikan kedudukan nilai itu dalam senarai argumen yang tinggal.

Pertanyaan berikut menggunakan fungsi FIELD untuk mengisih hasil berdasarkan kedudukan 'nama' nilai lajur dalam senarai ('B', 'A', 'D', 'E', 'C'):

SELECT id, name
FROM mytable
WHERE name IN ('B', 'A', 'D', 'E', 'C')
ORDER BY FIELD(name, 'B', 'A', 'D', 'E', 'C')
Salin selepas log masuk

Pertanyaan ini mengembalikan output berikut:

| id | nama |
^--------^---------^
| 5 | B |
| 6 | B |
| 1 | D |
| 15 | E |
| 17 | E |
| 9 | C |
| 18 | C |

Seperti yang anda lihat, baris kini disusun mengikut urutan yang asalnya dinyatakan dalam klausa IN().

Atas ialah kandungan terperinci Bagaimana Mengisih Keputusan MySQL mengikut Pesanan yang Ditentukan dalam Klausa IN()?. 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