尝试向数据库表中插入多条记录时,您可能会遇到“参数编号无效:参数未定义” 错误。当查询中指定的参数数量与作为输入提供的值的数量不匹配时,就会发生这种情况。
在提供的代码片段中:
$matches = array('1'); $count = count($matches); for($i = 0; $i < $count; ++$i) { $values[] = '(?)'; } // Build query $q = $this->dbc->prepare("INSERT INTO hashes (hash) VALUES " . implode(', ', $values) . " ON DUPLICATE KEY UPDATE hash = hash"); $q->execute($matches);
目标是使用准备好的语句将 $matches 中的值插入到哈希表中。但是,由于 $values 数组中的占位符参数 (?) 数量与 $matches 中的实际数据不对应而出现错误。
要解决此问题,请确保以下:
$matches = array('1'); $values = []; $count = count($matches); for($i = 0; $i < $count; ++$i) { $values[] = '(?)'; } // Insert query with named parameters (:hash) $sql = "INSERT INTO hashes (hash) VALUES (:hash) ON DUPLICATE KEY UPDATE hash = VALUES(:hash)"; $stmt = $dbh->prepare($sql); $data = $stmt->execute([':hash' => $matches]);
以上是为什么我的多重插入查询返回'无效参数号”?的详细内容。更多信息请关注PHP中文网其他相关文章!