如何将字符串值传递给存储过程中的 IN 子句?

Susan Sarandon
发布: 2024-10-26 04:28:30
原创
915 人浏览过

How to Pass a String of Values to an IN Clause in a Stored Procedure?

将变量传递给 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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!