Rumah  >  Artikel  >  pangkalan data  >  Bagaimana Mengisih Keputusan MySQL mengikut Pesanan yang Ditentukan dalam Klausa IN()?

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

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-12 17:28:01700semak imbas

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');

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')

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!

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