Heim > Datenbank > MySQL-Tutorial > Wie füge ich Daten in mehrere Tabellen in MySQL ein?

Wie füge ich Daten in mehrere Tabellen in MySQL ein?

Patricia Arquette
Freigeben: 2024-11-10 18:26:02
Original
374 Leute haben es durchsucht

How to Insert Data into Multiple Tables in MySQL?

Daten in mehrere Tabellen mit MySQL einfügen

Das gleichzeitige Einfügen von Daten in mehrere Tabellen in MySQL ist mit einer einzigen Abfrage nicht möglich. Es gibt jedoch alternative Ansätze, um dies zu erreichen:

Stapelverarbeitung

Sie können mehrere INSERT-Anweisungen als Stapel ausführen:

BEGIN;
INSERT INTO visits (visit_id, card_id) VALUES (NULL, 12131141);
INSERT INTO registration (registration_id, type, timestamp, visit_id)
VALUES (NULL, 'in', UNIX_TIMESTAMP(), LAST_INSERT_ID());
COMMIT;
Nach dem Login kopieren

Gespeicherte Prozedur

Alternativ können Sie eine gespeicherte Prozedur erstellen, die sowohl INSERT als auch INSERT kapselt Anweisungen:

CREATE PROCEDURE insert_into_multiple_tables(
  IN card_id INT
)
BEGIN
  INSERT INTO visits (visit_id, card_id) VALUES (NULL, card_id);
  INSERT INTO registration (registration_id, type, timestamp, visit_id)
  VALUES (NULL, 'in', UNIX_TIMESTAMP(), LAST_INSERT_ID());
END
Nach dem Login kopieren

Sie können dann die gespeicherte Prozedur mit der gewünschten Karten-ID ausführen:

CALL insert_into_multiple_tables(12131141);
Nach dem Login kopieren

Transaktionskontrolle

Um die Integrität der Daten sicherzustellen, müssen Sie kann den Batch oder die gespeicherte Prozedur in eine Transaktion einschließen:

BEGIN TRANSACTION;
-- Execute INSERT statements here
COMMIT;
Nach dem Login kopieren

Wenn eine der INSERT-Anweisungen fehlschlägt, wird die Transaktion zurückgesetzt, um dies sicherzustellen Die Daten in allen betroffenen Tabellen bleiben konsistent.

Das obige ist der detaillierte Inhalt vonWie füge ich Daten in mehrere Tabellen in MySQL 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