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中文網其他相關文章!