MySQL WHERE IN () Pertanyaan Tidak Mengembalikan Hasil Yang Dijangka
Dalam MySQL, pernyataan WHERE IN () biasanya digunakan untuk mendapatkan semula rekod berdasarkan pada satu set nilai yang ditentukan. Walau bagaimanapun, kadangkala pengguna menghadapi situasi di mana baris yang dijangka tidak dikembalikan dalam hasil.
Penerangan Masalah:
Seorang pengguna mempunyai pertanyaan yang memilih semua baris daripada "jadual " jadual di mana lajur "id" berada dalam senarai yang ditentukan:
<code class="sql">SELECT * FROM table WHERE id IN (1,2,3,4);</code>
Pengguna telah menyatakan bahawa apabila rekod mempunyai berbilang nilai "id" (cth., kedua-dua 1 dan 3), ia tidak dikembalikan dalam keputusan.
Memahami Isu:
Pernyataan WHERE IN () menterjemah senarai nilai yang disediakan ke dalam siri operator OR:
<code class="sql">SELECT * FROM table WHERE id='1' or id='2' or id='3' or id='4';</code>
Ini bermakna hanya baris di mana lajur "id" sepadan dengan tepat satu daripada nilai yang ditentukan akan dikembalikan.
Penyelesaian 1: Menggunakan FIND_IN_SET
Satu pendekatan untuk mengatasi had ini ialah mengubah suai struktur data dengan menukar jenis data lajur "id" kepada SET. Ini membolehkan lajur menyimpan berbilang nilai.
Menggunakan fungsi FIND_IN_SET, anda kemudiannya boleh mencari rekod yang terdapat nilai tertentu dalam SET:
<code class="sql">SELECT * FROM table WHERE FIND_IN_SET('1', id);</code>
Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa penyelesaian ini menimbulkan kerumitan tambahan dan mungkin tidak sesuai untuk semua senario.
Atas ialah kandungan terperinci Mengapa Pertanyaan MySQL WHERE IN () Saya Tidak Mengembalikan Rekod dengan Berbilang Nilai?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!