如何在 MySQL WHERE IN() 子句中處理具有多個值的記錄?

Barbara Streisand
發布: 2024-11-06 18:07:03
原創
176 人瀏覽過

How to Handle Records with Multiple Values in a MySQL WHERE IN() Clause?

MySQL IN () 運算子

查詢MySQL 資料庫時,WHERE IN () 運算子通常用於根據特定條件擷取行列中的值。例如,以下查詢從「table」表中擷取「id」列與任意值(1、2、3、4)相符的所有行:

<code class="sql">SELECT * FROM table WHERE id IN (1,2,3,4);</code>
登入後複製

但是,出現了問題當一筆記錄有多個“id”值時,例如1 和3。在這種情況下,查詢可能不會傳回該行。

解決方案

查詢翻譯符合以下 OR 條件:

<code class="sql">SELECT * FROM table WHERE id='1' or id='2' or id='3' or id='4';</code>
登入後複製

因此,它將只傳回與任何這些條件相符的行。

要解決此問題,一種選擇是使用 SET 資料類型作為 " id」列。這允許您使用逗號分隔的字串儲存多個值。然後,您可以使用 FIND_IN_SET() 函數搜尋特定值:

<code class="sql">SELECT * FROM table WHERE FIND_IN_SET('1', id);</code>
登入後複製

此查詢將傳回「id」列中值為「1」的所有行,無論任何行可能存在的其他值。

以上是如何在 MySQL WHERE IN() 子句中處理具有多個值的記錄?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板