这是我的PHP脚本的一大块,必须遗漏一些东西:
$startIndex = 7;
$endIndex = 303;
$defaults = range($startIndex, $endIndex);
$sql = "INSERT INTO items (itemId, userId) VALUES ";
$part = array_fill(0, count($defaults), "(?, ?)");
$sql .= implode(",", $part);
try {
$db = DB::getInstance();
$stmt = $db->dbh->prepare($sql);
$i = 1;
foreach($defaults as $default) {
$stmt->bindParam($i++, $default);
$stmt->bindparam($i++, $userId);
}
if ($stmt->execute()) {
echo "result=ok";
}else {
echo 'invalid query';
}
}catch(PDOException $e) {
echo $e->getMessage();
}
多次插入正在发生,一切似乎都很好,除了所有的itemId字段都以303($ defaults数组中的最后一个元素)形式出现。 foreach循环似乎正如我预期的那样工作,回显$ default给出了我期望的整数序列。所以,它必然是绑定的问题
请帮助:)
答案 0 :(得分:1)
这里发生的是你将参数绑定到$default
变量,而不是它的值。
循环$default
数组时,$defaults
的值会发生变化。绑定参数使用引用,而不是副本。
您可以更改循环和绑定参数以引用数组项:
foreach($defaults as $key => $default) {
$stmt->bindParam($i++, $defaults[$key]);
$stmt->bindparam($i++, $userId);
}