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

标签 php mysql pdo sql-insert

比如说,我们有多个行要插入到一个表中:

$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();

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

最佳答案

你至少有这两个选择:

$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 的观点,即在绝大多数实现中不会注意到性能差异。

关于php - 在 PHP PDO MYSQL 中插入多行的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26456219/

相关文章:

php - 在 laravel 中使用 mysql 查询计算行数

php - 为什么我的嵌套查询使 SQL Server 速度减慢这么多?

mysql - Laravel Eloquent 替换

php - 无法通过 php 连接到 mysql,但从命令行可以正常工作

php - 从许多 post_ids 中选择 1 个 MySQL 中的随机项目

mysql - 发送电子邮件至以 php 表单提交的电子邮件

php - Laravel 迁移在外键上爆炸。已经在使用 unsigned int 并引用创建的表

php - 在 Magento 中,有没有办法在创建后从可配置产品中删除属性?

PHP PDO INSERT WHERE NOT EXISTS 语句不起作用

php - PDO MySQL SQLSTATE[42000]