使用准备好的语句插入多行
使用准备好的语句插入多行是将数据添加到数据库同时保持安全性的便捷方法。想象一下,您有一个值数组要插入到数据库表中:
$values = [ [ 'val1' => 'val1', 'val2' => 'val2', 'val3' => 'val3' ], [ 'val1' => 'another_val1', 'val2' => 'another_val2', 'val3' => 'another_val3' ], // and so on... ];
使用单个插入查询
要使用准备好的语句插入这些行,我们可以使用带有多个 VALUES 子句的 INSERT 查询:
INSERT INTO table (col1, col2, col3) VALUES ( (:val11, :val21, :val31), (:val12, :val22, :val32), (:val13, :val23, :val33) )
对于每一行,我们创建一组参数,用命名参数替换静态值。这可确保每个参数单独绑定。
$params = []; foreach ($values as $row) { $params[':val1' . count($params)] = $row['val1']; $params[':val2' . count($params)] = $row['val2']; $params[':val3' . count($params)] = $row['val3']; } $sql = "INSERT INTO table (col1, col2, col3) VALUES (" . implode(',', array_keys($params)) . ")"; $stmt = DB::getInstance()->prepare($sql); $stmt->execute($params);
大量行的分块
如果要插入大量行,效率会更高将它们分成较小的批次,以避免过多的内存使用。您可以使用 array_chunk 将值数组分成更小的块。
$chunkSize = 100; // Adjust this to your needs $chunks = array_chunk($values, $chunkSize); foreach ($chunks as $chunk) { // Prepare and execute insert query for each chunk // ... }
替代方法:逐一插入
如果您需要单独插入每一行,您可以使用以下方法:
$stmt = DB::getInstance()->prepare( "INSERT INTO table (col1, col2, col3) VALUES (:val1, :val2, :val3)" ); foreach ($values as $row) { $stmt->bindParam(':val1', $row['val1']); $stmt->bindParam(':val2', $row['val2']); $stmt->bindParam(':val3', $row['val3']); $stmt->execute(); }
此方法效率较低,但对于大型应用程序可能是必要的数据集。
以上是如何在 PHP 中使用准备好的语句将多行插入数据库?的详细内容。更多信息请关注PHP中文网其他相关文章!