„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie kann ich mit Eloquent oder dem Query Builder mehrere Zeilen in eine Datenbank einfügen?

Wie kann ich mit Eloquent oder dem Query Builder mehrere Zeilen in eine Datenbank einfügen?

Veröffentlicht am 21.12.2024
Durchsuche:316

How Can I Insert Multiple Rows into a Database Using Eloquent or the Query Builder?

Mehrere Zeilen gleichzeitig mit Eloquent oder Fluent einfügen

Diese Untersuchung untersucht, wie man mit einer einzigen Abfrage innerhalb von Eloquent mehrere Zeilen in eine Datenbank einfügt (oder fließender) Rahmen. Das angegebene Beispiel ruft Daten mithilfe von UserSubject::where('user_id', Auth::id())->select('subject_id')->get(); ab. Die gewünschte Ausgabe erfordert jedoch das Einfügen dieser Daten in eine separate Tabelle mit einer bestimmten Spaltenstruktur.

Lösung:

Das Einfügen von Daten in großen Mengen wird durch Eloquent oder die Abfrage bequem erleichtert Baumeister. Betrachten Sie die folgenden Techniken:

  • Eloquenter Ansatz:

Utilize Model::insert($data); um mehrere Zeilen einzufügen. Dieser Ansatz umfasst Mutatoren, einschließlich Zeitstempel.

  • Query Builder-Ansatz:

Employ DB::table('table')->insert ($data); um Zeilen einzufügen, ohne Mutatoren aufzurufen.

Beispiel:

Gegeben ein Array von Zeilendaten:

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

Einfügung mit Eloquent:

Model::insert($data);

Einfügung mit dem Query Builder:

DB::table('table')->insert($data);
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3