这个问题已经在这里有了答案 :
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)
我真正做到这一点的唯一方法是将值放置在字符串本身内而不绑定它们,但是我知道一定有一种更简单的方法可以做到这一点。