mySQL: Update if exists else insert record (SQL statement)

Wenn Sie einen Datensatz in eine Datenbanktabelle einfügen möchten (wenn er noch nicht existiert) oder diesen updaten möchten (wenn er existiert), hilft dieser SQL Befehl:

INSERT INTO table (fields) VALUES (values) ON DUPLICATE KEY UPDATE field = value

Dieses Statement prüft, ob der Primary Key (PK) für den einzufügenden Datensatz bereits besteht, nutzt dann ein Update Befehl und ansonsten Ihren angegeben Insert Befehl.

Beispiel

Wir haben eine Tabelle "Test" mit den Feldern "A", "B" (je vom Typ varchar) und "C" (integer). Die Felder "A" und "B" sind unser PK.

Ein normales SQL Insert Statement in die leere Tabelle:

insert into Test (A,B,C) values ('Testtext A1','Texttext B1', 110);
insert into Test (A,B,C) values ('Testtext A2','Texttext B2', 250);

Danach stehen folgende Daten in der Tabelle "Test":

ABC
Testtext A1Texttext B1110
Testtext A2Texttext B2250

Nun möchten wir einen weiteren Datensatz einfügen. Werden unter dem PK Daten gefunden, sollen diese überschrieben (aktualisiert) werden - ansonsten wird der Datensatz normal eingefügt:

insert into Test (A,B,C) values ('Testtext A2','Texttext B2', 285) ON DUPLICATE KEY UPDATE C = 285;
INSERT into Test (A,B,C) values ('Testtext A3','Texttext B3', 310) ON DUPLICATE KEY UPDATE C = 310;

Jetzt sieht der Inhalt der Tabelle "Test" wie folgt aus:

ABC
Testtext A1Texttext B1110
Testtext A2Texttext B2285
Testtext A3Texttext B3310

Die roten Texte sind im Gegensatz zur ersten Ansicht verändert.

insert into Test (A,B,C) values ('Testtext A2','Texttext B2', 285) ON DUPLICATE KEY UPDATE C = 28

Dieser Artikel hat Dir geholfen ?
.. und Dir nerviges Ausprobieren, Suchen und Zeit erspart ?

Dann würde ich mich sehr freuen, wenn Du diese werbefreie Hilfeseite mit einer kleinen Anerkennung unterstützen würdest.
Vielen Dank !
PayPal Donate QR Code

Schreibe einen Kommentar

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

6 − vier =