在SQL Server 中,當嘗試透過單一變數將包含多個值的字串傳遞給IN 子句時,會出現常見的限制。當基於一組值有條件地查詢資料時,這可能會帶來挑戰。
考慮以下帶有 SELECT 語句的預存程序:
SELECT product_id, product_price FROM product WHERE product_type IN ('AA','BB','CC');
目標就是修改此查詢以接受包含逗號分隔值的變數。
FIND_IN_SET 函數提供了此問題的解決方案。此函數檢查是否在給定字串中找到指定的子字串。透過使用此函數,您可以如下重寫查詢:
SELECT product_id, product_price FROM product WHERE FIND_IN_SET(product_type, param);
這裡,param 表示包含逗號分隔值的變數。例如,如果參數包含值“AA,BB,CC”,則查詢將檢索 Product_type 列與這些值中的任何一個相符的行。
以上是以下是一些標題選項,每個標題都強調問題的一個略有不同的方面: **選項 1:關注限制** * **如何將多個值傳遞給 SQL Server 中的 IN 子句? **O的詳細內容。更多資訊請關注PHP中文網其他相關文章!