in的绑定 mysql_MySQL IN语句的PDO绑定值[重复]

这个问题已经在这里有了答案 :

2个月前关闭。

我对PDO有一个问题,在困扰了一段时间后,我真的很想得到答案。

举个例子:

我将ID数组绑定到PDO语句,以便在MySQL IN语句中使用。

该数组将说: $ values = array(1,2,3,4,5,6,7,8);

数据库安全变量为 $ products = implode(’,’$ values);

因此, $ products 将是一个 STRING ,其值为: ‘1,2,3,4,5,6,7,8’

该语句如下所示:

SELECT users.id

FROM users

JOIN products

ON products.user_id = users.id

WHERE products IN (:products)

当然, $ products 将被绑定为 :products 。

但是,在编译该语句并绑定值时,它实际上看起来像这样:

SELECT users.id

FROM users

JOIN products

ON products.user_id = users.id

WHERE products IN ('1,2,3,4,5,6,7,8')

问题是它正在将IN语句中的所有内容作为单个字符串执行,因为我已经将其准备为逗号分隔的值以绑定到该语句。

我真正需要的是:

SELECT users.id

FROM users

JOIN products

ON products.user_id = users.id

WHERE products IN (1,2,3,4,5,6,7,8)

我真正做到这一点的唯一方法是将值放置在字符串本身内而不绑定它们,但是我知道一定有一种更简单的方法可以做到这一点。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值