Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Doctrine2 - Inserção múltipla em um tiro


De acordo com esta resposta , o Doctrine2 não permite que você combine várias instruções INSERT em uma:

Você pode ler mais sobre o processamento em lote do Doctrine2 aqui:http://www .doctrine-project.org/blog/doctrine2-batch-processing.html

Você pode alternar para DBAL ou recorrer ao processamento de seus dados em pequenos lotes, liberando seu gerenciador de entidade após uma quantidade definida de inserções:
$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();