一尘不染

已准备好PDO在单个查询中插入多行

php

我目前在MySQL上使用这种类型的SQL在单个查询中插入多行值:

INSERT INTO `tbl` (`key1`,`key2`) VALUES ('r1v1','r1v2'),('r2v1','r2v2'),...

关于PDO的阅读,使用准备好的语句应该比静态查询为我提供更好的安全性。

因此,我想知道是否可以使用准备好的语句生成“通过使用一个查询插入多行值”。

如果是,请问我该如何实施?


阅读 347

收藏
2020-05-26

共1个答案

一尘不染

使用PDO预准备语句插入多值

在一个execute语句中插入多个值。为什么这样,因为根据此页面,它比常规插入更快。

$datafields = array('fielda', 'fieldb', ... );

$data[] = array('fielda' => 'value', 'fieldb' => 'value' ....);
$data[] = array('fielda' => 'value', 'fieldb' => 'value' ....);

更多的数据值,或者您可能有一个循环来填充数据。

使用准备好的插入,您需要知道要插入的字段以及创建?的字段数。占位符以绑定您的参数。

insert into table (fielda, fieldb, ... ) values (?,?...), (?,?...)....

基本上,这就是我们希望插入语句看起来的样子。

现在,代码:

function placeholders($text, $count=0, $separator=","){
    $result = array();
    if($count > 0){
        for($x=0; $x<$count; $x++){
            $result[] = $text;
        }
    }

    return implode($separator, $result);
}

$pdo->beginTransaction(); // also helps speed up your inserts.
$insert_values = array();
foreach($data as $d){
    $question_marks[] = '('  . placeholders('?', sizeof($d)) . ')';
    $insert_values = array_merge($insert_values, array_values($d));
}

$sql = "INSERT INTO table (" . implode(",", $datafields ) . ") VALUES " .
       implode(',', $question_marks);

$stmt = $pdo->prepare ($sql);
try {
    $stmt->execute($insert_values);
} catch (PDOException $e){
    echo $e->getMessage();
}
$pdo->commit();

尽管在我的测试中,使用多个刀片和具有单个值的常规预加工刀片仅相差1秒。

2020-05-26