So führen Sie ein effizientes UPSERT mit mehreren Spalten durch
Das Einfügen oder Aktualisieren von Daten in eine Datenbanktabelle mithilfe von UPSERT (Einfügen bei doppelter Aktualisierung) kann eine gemeinsame Aufgabe sein. Wenn Sie jedoch mit mehreren Spalten in einer Update-Anweisung arbeiten, ist es wichtig, Leistung und Wartbarkeit zu berücksichtigen.
Umgang mit mehreren Spalten in einem UPSERT
In Ihrem Beispiel zielen Sie darauf ab um eine Zeile in der Artikeltabelle einzufügen oder zu aktualisieren und den Wert „items_in_stock“ zu erhöhen, wenn die Zeile vorhanden ist. Während Ihr anfänglicher Ansatz mit einer Unterabfrage im Aktualisierungsteil logisch erscheinen mag, führt er zu unnötiger Komplexität.
Prägnante Aktualisierungsanweisungen bevorzugen
Ein besserer Ansatz besteht darin, Unterabfragen zu vermeiden die Update-Anweisung. Nutzen Sie stattdessen die Fähigkeit von MySQL, auf die alten und neuen Werte der aktualisierten Spalten zu verweisen. Dadurch können Sie prägnante und effiziente Aktualisierungsanweisungen schreiben.
Beispiel für die Verwendung der Wertreferenzierung von MySQL
Betrachten Sie die folgende UPSERT-Anweisung:
INSERT INTO `item` (`item_name`, `items_in_stock`) VALUES( 'A', 27) ON DUPLICATE KEY UPDATE `items_in_stock` = `items_in_stock` + 27;
In In diesem Beispiel wird der Wert „items_in_stock“ aktualisiert, indem der neue Wert „items_in_stock“ zum vorherigen hinzugefügt wird. MySQL verweist automatisch auf den alten Wert „items_in_stock“, sodass keine Unterabfrage erforderlich ist.
Vorteile dieses Ansatzes:
Immer berücksichtigen Einfachheit
Denken Sie daran, dass die effektivsten Lösungen oft die einfachsten sind. Wenn Sie feststellen, dass Sie ein Problem zu kompliziert machen, ist es wahrscheinlich, dass Sie den falschen Ansatz wählen. Setzen Sie auf Einfachheit und suchen Sie nach effizienten und wartbaren Lösungen für Ihren Datenbankbetrieb.
Das obige ist der detaillierte Inhalt vonWie kann man UPSERT mit mehreren Spalten in MySQL effizient durchführen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!