Bei der Arbeit mit mehreren Tabellen, die durch ein gemeinsames Feld verbunden sind, kann es erforderlich sein, Informationen über einen Benutzer zu löschen von allen Tischen gleichzeitig. Anstatt mehrere DELETE-Anweisungen auszuführen, untersucht diese Abfrage die Möglichkeit, den Löschvorgang in einer einzigen Abfrage durchzuführen.
Die vorgeschlagene Abfrage umfasst die Verwendung mehrerer durch Semikolons getrennter DELETE-Anweisungen:
DELETE FROM table1 WHERE user_id='$user_id'; DELETE FROM table2 WHERE user_id='$user_id'; DELETE FROM table3 WHERE user_id='$user_id'; DELETE FROM table4 WHERE user_id='$user_id';
Laut der MySQL-Dokumentation ist dies jedoch nicht der optimale Ansatz. Die Dokumentation schlägt die Verwendung der folgenden Syntax vor:
DELETE t1, t2 FROM t1 INNER JOIN t2 INNER JOIN t3 WHERE t1.id=t2.id AND t2.id=t3.id;
Diese Abfrage ermöglicht das Löschen von Zeilen aus mehreren Tabellen basierend auf einer angegebenen Bedingung in der WHERE-Klausel. In diesem Fall wäre die Bedingung t1.user_id='$user_id'.
Die Verwendung dieses Ansatzes vereinfacht den Löschvorgang und stellt sicher, dass die Daten aus allen relevanten Tabellen gleichzeitig entfernt werden.
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