微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP – 如何在预处理语句中将数组替换为主机参数

我能够绑定int,str,bool和null类型的值,但我无法绑定数组类型.
我已经尝试了两个函数,即bindValue和bindParam,但它们都没有工作.
我怎么能做到这一点?
// a helper function to map sqlite data type
function getArgType($arg) {
    switch (gettype($arg)) {
        case 'double':  return sqlite3_FLOAT;
        case 'integer': return sqlite3_INTEGER;
        case 'boolean': return sqlite3_INTEGER;
        case 'NULL':    return sqlite3_NULL;
        case 'string':  return sqlite3_TEXT;
        default:
            throw new \invalidargumentexception('Argument is of invalid type '.gettype($arg));
    }
}

$sql = "SELECT * FROM table_name WHERE id IN (?)";
$params = [[10,9,6]]; // array of array
$dbpath = '/path/to/sqlite.sqlite';
$db = new sqlite3($dbPath,sqlite3_OPEN_READONLY);
$stmt = $db->prepare($sql);

try {
    foreach ($params as $index => $val) {
        if (is_array($val)) {
            /************* I am stuck here  *************/
            $ok = $stmt->bindParam($index + 1,$val);
            // Using bindValue also didn't worked!
        } else {
            $ok = $stmt->bindValue($index + 1,$val,getArgType($val));
        }

        if (!$ok) {
            throw new Exception("Unable to bind param: $val");
        }
    }
} catch (Exception $ex) {
    // NO exception is thrown from bindValue() or bindparam()
    $reason = "Error in binding statement. " . $ex->getMessage();
    die($reason);
}

$result = $stmt->execute();
$data = [];
while ($row = $result->fetchArray($mode)) {
    $data[] = $row;
}
var_dump($data);

编辑:我已经尝试过替换单身?在param数组中包含所需数量的问号,但只有当我的数组的值小于1000时它才有效!我认为这是PHPsqlite3中语句编写方式的限制.

不幸的是,这是不可能的!您无法绑定数组.

对您来说最简单的解决方案是:

>使用数组中的每个值创建一个占位符(?)的SQL查询
>通过遍历数组来绑定每个值.

但是还有另外一种选择(例如子SELECT)

More information here(即使它是一个Java问题,它几乎是相同的主题/问题,因为在这种情况下数据库类型无关紧要)

编辑:通常,绑定参数的sql限制设置为999,但是你是can change it if you need to.

原文地址:https://www.jb51.cc/php/134894.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐