Memastikan Hasil Tertib dengan Klausa IN() SQL
KlausaSQL IN()
sememangnya tidak menjamin susunan hasil. Ini selalunya membawa kepada output yang tidak dijangka apabila anda memerlukan hasil untuk menggambarkan susunan tertentu, seperti yang dilihat dalam senario yang memerlukan dua pertanyaan: satu untuk mendapatkan ID dalam urutan yang ditentukan dan satu lagi untuk mengambil data berdasarkan ID tersebut. Pertanyaan kedua kerap mengembalikan data daripada susunan yang dikehendaki.
Pendekatan Unggul: Menggunakan Fungsi FIELD() MySQL
Daripada bergantung pada jadual sementara, fungsi FIELD()
MySQL menawarkan penyelesaian yang lebih elegan. FIELD()
memberikan pangkat kepada setiap nilai dalam klausa IN()
mengikut kedudukannya. Memanfaatkan FIELD()
dalam klausa ORDER BY
pertanyaan pengambilan data anda memastikan hasil sepadan dengan susunan ID dalam pertanyaan awal anda.
Contoh Praktikal:
Pertanyaan yang disemak ini mempamerkan fungsi FIELD()
:
<code class="language-sql">SELECT name, description, ... FROM ... WHERE id IN ([ids, any order]) ORDER BY FIELD(id, [ids in desired order])</code>
Memahami Kefungsian FIELD():
FIELD()
menerima berbilang hujah. Yang pertama ialah nilai untuk dicari, diikuti oleh padanan yang berpotensi. Contohnya:
<code class="language-sql">FIELD('a', 'a', 'b', 'c')</code>
Keputusan: 1 ('a' ialah nilai pertama dan sepadan dengan hujah pertama)
<code class="language-sql">FIELD('a', 'c', 'b', 'a')</code>
Keputusan: 3 ('a' ialah nilai pertama dan sepadan dengan hujah ketiga)
Dengan memasukkan FIELD()
ke dalam klausa ORDER BY
anda, anda mengawal tertib hasil, walaupun jika klausa IN()
mengandungi ID dalam urutan arbitrari. Pendekatan ini mengelakkan overhed jadual sementara.
Pertimbangan Khusus Pangkalan Data:
Perhatikan bahawa FIELD()
adalah khusus MySQL. Sistem pangkalan data lain mungkin mempunyai fungsi yang setara atau memerlukan kaedah alternatif untuk mengekalkan susunan keputusan. Rujuk dokumentasi pangkalan data anda untuk mendapatkan alternatif yang sesuai.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menjamin Susunan Keputusan Apabila Menggunakan Klausa IN() SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!