Wie füge ich mehrere Zeilen effizient mit Eloquent oder Query Builder in Laravel ein?

Mary-Kate Olsen
Freigeben: 2024-11-20 01:10:03
Original
706 Leute haben es durchsucht

How to Efficiently Insert Multiple Rows Using Eloquent or Query Builder in Laravel?

Einfügen mehrerer Zeilen mit Eloquent/Fluent

Sie möchten mehrere Zeilen in eine andere Tabelle einfügen, basierend auf einer Abfrage, die Daten von einem bestimmten abruft Tisch. Lassen Sie uns verstehen, wie dies mit Eloquent oder dem Abfrage-Builder erreicht werden kann.

Um Daten mit Eloquent massenhaft einzufügen:

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

Model::insert($data); // Calls mutators including timestamps
Nach dem Login kopieren

Alternativ können Sie den Abfrage-Builder verwenden:

DB::table('table')->insert($data); // Does not call mutators
Nach dem Login kopieren

In Ihrem Fall können Sie die $query ändern, um die gewünschten Daten abzurufen, und sie dann mit einer der oben genannten Methoden in die andere Tabelle einfügen.

Denken Sie daran, dass Sie die Anzahl der Zeilen dynamisch bestimmen können in $query mit:

$rowCount = count($query);
Nach dem Login kopieren

Diese Informationen können Ihnen bei Bedarf beim Durchlaufen der Zeilen helfen.

Das obige ist der detaillierte Inhalt vonWie füge ich mehrere Zeilen effizient mit Eloquent oder Query Builder in Laravel ein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage