mysql pdo in_PDO如何绑定IN()语句的array变量

我的sql语句中有IN的条件,在我的想象中可以这样写代码$ids = array(2344, 5523, 9332);

$st = $pdo->prepare('SELECT * FROM table_name WHERE id IN (:id)');

$st->bindParam('id', $ids);

$st->execute();

但这样执行pdo会报错,无法绑定一个array变量,有没有好的解决方法呢

回复内容:

我的sql语句中有IN的条件,在我的想象中可以这样写代码$ids = array(2344, 5523, 9332);

$st = $pdo->prepare('SELECT * FROM table_name WHERE id IN (:id)');

$st->bindParam('id', $ids);

$st->execute();

但这样执行pdo会报错,无法绑定一个array变量,有没有好的解决方法呢

PDO不支持绑定数组。

要么别用绑定了,$ids = array(2344, 5523, 9332);

// 过滤ids略

$in = implode(',',$ids);

$st = $pdo->prepare('SELECT * FROM table_name WHERE id IN ('.$in.')');

$st->execute();

如果你坚持用绑定或许只能这样$ids = array(2344, 5523, 9332);

// 自动构造多个?号略

$st = $pdo->prepare('SELECT * FROM table_name WHERE id IN (?,?,?)');

foreach ($ids as $k => $id)

$st->bindValue(($k+1), $id);

$st->execute();

上午刚说过这个问题,PDO不支持这种绑定,参见:

http://segmentfault.com/q/10100000001... 第三条。

08年写lotusphp的文档时专门标注了,PDO不支持这个,楼上zhao yi也是lotusphp开发者

PDO是不支持这种绑定的,但是可以通过第三方的Class来实现,这个是我做的一个PDO Class,可以实现安全的WHERE IN,而且使用也方便。

https://github.com/lincanbin/PHP-PDO-MySQL-Class

使用方法也很简单,先new一个对象

然后

query("SELECT * FROM fruit WHERE name IN (?)",array('apple','banana'));

?>

即可,其他的SQL语法使用可以看https://github.com/lincanbin/PHP-PDO-MySQL-Class

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值