我尝试将SQLite事务和预准备语句组合在一起,以获得数千条记录的最佳插入速度。但是,所有插入的行都是空的。
在插入之前打印变量表明它们具有正确的数据并且没有错误。
$db->beginTransaction();
$insert_stmt = $db->prepare("INSERT INTO `table` VALUES (:id, :value2, :value3, :value4)");
$insert_stmt->bindValue(":id", $id);
$insert_stmt->bindValue(":value2", $value2);
$insert_stmt->bindValue(":value3", $value3);
$insert_stmt->bindValue(":value4", $value4);
foreach ($records as $record)
{
$id = $record["id"];
$value2 = $record["value2"];
$value3 = $record["value3"];
$value4 = $record["value4"];
$insert_stmt->execute();
print_r($db->errorInfo()); // print errors
}
$db->commit();
答案 0 :(得分:0)
您必须将bindValue
次调用放入循环中。
执行bindValue
时,值会复制到语句中。无论你以后做过什么变量,都无关紧要。