Mengapa Pertanyaan MySQL WHERE IN () Saya Tidak Mengembalikan Rekod dengan Berbilang Nilai?

Mary-Kate Olsen
Lepaskan: 2024-11-04 17:54:02
asal
402 orang telah melayarinya

Why Doesn't My MySQL WHERE IN () Query Return Records with Multiple Values?

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan