php - PDO如何绑定IN()语句的array变量
PHP中文网
PHP中文网 2017-04-10 13:11:59
[PHP讨论组]

我的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变量,有没有好的解决方法呢

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(2)
大家讲道理

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();
ringa_lee

可以参考下,首先遍历构造几个问号,然后绑定参数

  public function getMdtInfoByMdtID($mdtID)
    {
        $in = '';
        foreach ($mdtID as $value) {
            $in .= '?,';
        }
        $in = rtrim($in, ',');
        $sql = 'select * from ' . $this->tableName . ' where MdtID in (' . $in . ')';
        $st = self::$handle->prepare($sql);
        $st->execute($mdtID);
        return $st->fetchAll(PDO::FETCH_ASSOC);

    }
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号