将变量传递给 IN 子句
考虑一个包含 IN 子句的 SELECT 语句的存储过程:
SELECT product_id, product_price FROM product WHERE product_type IN ('AA','BB','CC');
如果您希望从包含一串值的单个变量填充 IN 子句值,例如:
'AA,BB,CC'
使用此方法可能会遇到困难。解决方案如下:
不要尝试将字符串直接传递给 IN 子句,而是将其作为以下格式的参数值传递:
'AA,BB,CC'
利用 FIND_IN_SET 函数来确定是否每个product_type 值都出现在输入参数中:
SELECT product_id, product_price FROM product WHERE FIND_IN_SET(product_type, param);
在此修改后的语句中,param 表示包含值字符串的输入参数。
以上是如何将字符串值传递给存储过程中的 IN 子句?的详细内容。更多信息请关注PHP中文网其他相关文章!