在PHP PDO MYSQL中插入多行的最佳方法是什么?

2022-08-30 22:08:39

假设,我们要在表中插入多行:

$rows = [(1,2,3), (4,5,6), (7,8,9) ... ] //[ array of values ];

使用 PDO:

$sql = "insert into `table_name` (col1, col2, col3) values (?, ?, ?)" ;

现在,您应该如何继续插入行?喜欢这个?

$stmt = $db->prepare($sql);

foreach($rows as $row){
  $stmt->execute($row);
}

或者,像这样?

$sql = "insert into `table_name` (col1, col2, col3) values ";
$sql .= //not sure the best way to concatenate all the values, use implode?
$db->prepare($sql)->execute();

哪种方式会更快,更安全?插入多行的最佳方法是什么?


答案 1

您至少有以下两个选项:

$rows = [(1,2,3), (4,5,6), (7,8,9) ... ];

$sql = "insert into `table_name` (col1, col2, col3) values (?,?,?)";

$stmt = $db->prepare($sql);

foreach($rows as $row)
{
    $stmt->execute($row);
}

OR:

$rows = [(1,2,3), (4,5,6), (7,8,9) ... ];

$sql = "insert into `table_name` (col1, col2, col3) values ";

$paramArray = array();

$sqlArray = array();

foreach($rows as $row)
{
    $sqlArray[] = '(' . implode(',', array_fill(0, count($row), '?')) . ')';

    foreach($row as $element)
    {
        $paramArray[] = $element;
    }
}

// $sqlArray will look like: ["(?,?,?)", "(?,?,?)", ... ]

// Your $paramArray will basically be a flattened version of $rows.

$sql .= implode(',', $sqlArray);

$stmt = $db->prepare($sql);

$stmt->execute($paramArray);

如您所见,第一个版本具有更简单的代码;但是,第二个版本确实执行批处理插入。批处理插入应该更快,但我同意@BillKarwin,即在绝大多数实现中不会注意到性能差异。


答案 2

我会用第一种方法来准备语句,用一行参数占位符准备语句,然后一次插入一行,并执行。

$stmt = $db->prepare($sql);

foreach($rows as $row){
    $stmt-> execute($row);
}

它不如在单个插入中执行多行那么快,但它足够接近,您可能永远不会注意到差异。

这样做的好处是,使用代码非常容易。这就是为什么你使用PHP的原因,为了开发人员的效率,而不是运行时的效率。

如果有许多行(数百或数千行),并且性能是重中之重,则应考虑使用“加载数据文件”。


推荐