Rumah > Artikel > pangkalan data > Bagaimanakah Saya Boleh Mendapatkan Data dalam Pesanan Tertentu dalam MySQL Tanpa Bergantung pada Nilai Medan?
Memelihara Susunan dalam Keputusan Pertanyaan: Penyelesaian
Dalam MySQL, mendapatkan semula data dalam susunan tertentu tanpa bergantung pada nilai medan tertentu boleh mencabar. Pertimbangkan senario berikut: memilih ID 7, 2, 5, 9 dan 8 sambil mengekalkan susunan yang tepat ini sebagai hasilnya.
Pendekatan tradisional menggunakan klausa IN, seperti yang ditunjukkan dalam contoh yang disediakan, tidak menjamin susunan yang dikehendaki. Walau bagaimanapun, penyelesaian menarik telah muncul yang memanfaatkan fungsi FIND_IN_SET:
SELECT id FROM table WHERE id in (7, 2, 5, 9, 8) ORDER BY FIND_IN_SET(id, "7,2,5,9,8");
Pertanyaan ini secara berkesan memberikan setiap ID kedudukan dalam urutan "7,2,5,9,8". Fungsi FIND_IN_SET mengembalikan kedudukan ID dalam urutan yang diberikan. Sebagai contoh, ID 7 berada pada kedudukan 1, ID 2 berada pada kedudukan 2 dan seterusnya.
Dengan mengisih keputusan mengikut output FIND_IN_SET, pertanyaan memastikan bahawa ID yang diambil sejajar dengan susunan yang ditentukan dalam hujah kedua. Penyelesaian rumit ini membolehkan pembangun mengenakan perintah yang telah ditetapkan pada hasil pertanyaan, membuka kemungkinan baharu untuk manipulasi data.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mendapatkan Data dalam Pesanan Tertentu dalam MySQL Tanpa Bergantung pada Nilai Medan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!