Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Doctrine2 - Mehrere Einfügungen in einem Schuss

Laut dieser Antwort , Doctrine2 erlaubt es Ihnen nicht, mehrere INSERT-Anweisungen zu einer zu kombinieren:

Hier können Sie mehr über die Stapelverarbeitung von Doctrine2 lesen:http://www .doctrine-project.org/blog/doctrine2-batch-processing.html

Sie können entweder zu DBAL wechseln oder Ihre Daten in kleinen Batches verarbeiten, indem Sie Ihren Entitätsmanager nach einer festgelegten Anzahl von Einfügungen leeren:

$batchSize = 20;

foreach ($items as $i => $item) {
     $product = new Product($item['datas']);

     $em->persist($product);

     // flush everything to the database every 20 inserts
     if (($i % $batchSize) == 0) {
         $em->flush();
         $em->clear();
    }
}

// flush the remaining objects
$em->flush();
$em->clear();