219 votes

Insertion en masse dans Laravel à l'aide d'eloquent ORM

Comment effectuer des insertions de base de données en masse dans Laravel en utilisant Eloquent ORM ?

Je travaille avec un document XML, en parcourant ses éléments en boucle. Je veux accomplir quelque chose comme cela dans Laravel :

$sXML = download_page('http://remotepage.php&function=getItems&count=100&page=1');
$oXML = new SimpleXMLElement($sXML);
$query = "INSERT INTO tbl_item (first_name, last_name, date_added) VALUES";
foreach($oXML->results->item->item as $oEntry){
    $query .=  "('" . $oEntry->firstname . "', '" . $oEntry->lastname . "', '" . date("Y-m-d H:i:s") . "'),";
}
mysql_query($query);

mais j'obtiens l'erreur suivante.

SQLSTATE [HY093] : Invalid parameter number : mixed named and positional parameters.

1 votes

Avez-vous un has_many relation sur vos modèles ?

1 votes

Non, je n'ai pas de relations en ce moment.

0 votes

@DavidBarker J'ai essayé de former la chaîne de questions en utilisant une boucle for. J'ai également essayé d'utiliser les transactions dans Laravel.

406voto

GTF Points 699

Vous pouvez simplement utiliser Eloquent::insert() .

Par exemple :

$data = [
    ['name'=>'Coder 1', 'rep'=>'4096'],
    ['name'=>'Coder 2', 'rep'=>'2048'],
    //...
];

Coder::insert($data);

94voto

Nous pouvons mettre à jour la réponse GTF pour mettre à jour les timestamps facilement.

$data = array(
    array(
        'name'=>'Coder 1', 'rep'=>'4096',
        'created_at'=>date('Y-m-d H:i:s'),
        'modified_at'=> date('Y-m-d H:i:s')
       ),
    array(
         'name'=>'Coder 2', 'rep'=>'2048',
         'created_at'=>date('Y-m-d H:i:s'),
         'modified_at'=> date('Y-m-d H:i:s')
       ),
    //...
);

Coder::insert($data);

Mise à jour : pour simplifier la date, nous pouvons utiliser le carbone comme le suggère @Pedro Moreira

$now = Carbon::now('utc')->toDateTimeString();
$data = array(
    array(
        'name'=>'Coder 1', 'rep'=>'4096',
        'created_at'=> $now,
        'modified_at'=> $now
       ),
    array(
         'name'=>'Coder 2', 'rep'=>'2048',
         'created_at'=> $now,
         'modified_at'=> $now
       ),
    //...
);

Coder::insert($data);

UPDATE2 : pour laravel 5 , utilisez updated_at au lieu de modified_at

$now = Carbon::now('utc')->toDateTimeString();
$data = array(
    array(
        'name'=>'Coder 1', 'rep'=>'4096',
        'created_at'=> $now,
        'updated_at'=> $now
       ),
    array(
         'name'=>'Coder 2', 'rep'=>'2048',
         'created_at'=> $now,
         'updated_at'=> $now
       ),
    //...
);

Coder::insert($data);

43voto

imal365 Points 39

Voici comment le faire de manière plus éloquente,

    $allinterests = [];
    foreach($interests as $item){ // $interests array contains input data
        $interestcat = new User_Category();
        $interestcat->memberid = $item->memberid;
        $interestcat->catid = $item->catid;
        $allinterests[] = $interestcat->attributesToArray();
    }
    User_Category::insert($allinterests);

30voto

Alex Points 1165

Pour ceux qui lisent ceci, regardez createMany() méthode .

/**
 * Create a Collection of new instances of the related model.
 *
 * @param  array  $records
 * @return \Illuminate\Database\Eloquent\Collection
 */
public function createMany(array $records)
{
    $instances = $this->related->newCollection();

    foreach ($records as $record) {
        $instances->push($this->create($record));
    }

    return $instances;
}

8voto

user3716003 Points 61

Je l'ai cherché plusieurs fois, et j'ai finalement utilisé un modèle personnalisé. timestamps comme ci-dessous :

$now = Carbon::now()->toDateTimeString();
Model::insert([
    ['name'=>'Foo', 'created_at'=>$now, 'updated_at'=>$now],
    ['name'=>'Bar', 'created_at'=>$now, 'updated_at'=>$now],
    ['name'=>'Baz', 'created_at'=>$now, 'updated_at'=>$now],
    ..................................
]);

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X