PHP PDO Mysql Insert Performance

前端 未结 3 1365
鱼传尺愫
鱼传尺愫 2021-01-28 03:43

I normally don\'t use a lot of SQL stuff in PHP but recently have been forced into it by a friend as to help him debug something.

I am using PDO with PHP to insert some

相关标签:
3条回答
  • 2021-01-28 04:22

    Turns out that a setting inside the SQL server is what was causing it. As far as I can tell the transaction commit was set to flush to disk on every write:

    innodb_flush_log_at_trx_commit=0
    

    This is the default ACID compliant settings of a new install.

    I changed my setting to this

    innodb_flush_log_at_trx_commit=2
    

    This allows ONLY power outage or OS crash to erase the transaction buffer/log and not a mysqld crash.

    For some people who need the "D" of ACID to be 100% true then you should leave this setting alone.

    0 讨论(0)
  • 2021-01-28 04:24

    found this one. Performance in PDO / PHP / MySQL: transaction versus direct execution. so try this one.

    $query = $data->prepare("INSERT INTO `tbl_temp` (aid, bid) VALUES (?, ?)");
    try {
            $data->beginTransaction();
            for($i=0; $i < 150; $i++) {
                $time = time();
                $query->bindValue(1, $i, PDO::PARAM_INT);
                $query->bindValue(2, $time, PDO::PARAM_STR);
                $query->execute();
            }
            $data->commit();
        } catch(PDOException $e) {
                $data->rollBack();
        }
    
    0 讨论(0)
  • 2021-01-28 04:33

    As Simon stated in a comment, there is no use of doing the preparation within the loop. Doing so will cause 300 queries to be sent to the database, each time one for the preparation and on for the actual insert. Using the prepare-statement before will cause only 151 queries:

    $query = $data->prepare("INSERT INTO `tbl_temp` (aid, bid) VALUES (?, ?)");
    for ($i = 1; $i <= 150; $i++) {
        $time = time();
        $query->execute(array($i, $time));
    }
    

    Another idea could be to use instead a combined multi insert statement. I guess it could have a better performance, but I'm not quite sure:

    $query = 'INSERT INTO `tbl_temp` (aid, bid) VALUES';
    for ($i = 1; $i <= 150; $i++) {
        if ($i == 1) {
            $query .= ' ('.$i.', '.time().')';
        } else {
            $query .= ', ('.$i.', '.time().')';
        }
    }
    $data->exec($query);
    
    0 讨论(0)
提交回复
热议问题