將變數傳遞給IN 子句
將包含值列表的變數傳遞給SQL 語句中的IN 子句可能是理想的選擇。但是,某些程式語言本身並不支援此功能。本文探討了使用 FIND_IN_SET 函數的解決方法。
範例場景
考慮以下帶有SELECT 語句的預存程序:
<code class="sql">SELECT product_id, product_price FROM product WHERE product_type IN ('AA','BB','CC');</code>
目標是將包含值字串('AA, BB,CC') 的單一變數input_variables 傳遞給WHERE 子句。
使用 FIND_IN_SET
到要實現此目的,請將參數值作為逗號分隔的字串傳遞:'AA,BB,CC'。然後,利用 FIND_IN_SET 函數:
<code class="sql">SELECT product_id, product_price FROM product WHERE FIND_IN_SET(product_type, param);</code>
如果在集合中找到指定的字串,FIND_IN_SET 函數將傳回 1,如果沒有,則傳回 0。因此,WHERE 子句僅傳回 Product_type 欄位與 param 變數中的值之一相符的行。
以上是如何在 SQL 中將變數傳遞給 IN 子句:使用 FIND_IN_SET 的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!