您好,欢迎访问一九零五行业门户网

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
其它类似信息

推荐信息