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!