Heim >Datenbank >MySQL-Tutorial >Wie verwende ich Unterabfragen in MySQL-DELETE-Anweisungen korrekt, um Syntaxfehler zu vermeiden?
MySQL DELETE-Anweisung mit Unterabfrage als Bedingung
In MySQL können Sie mit der DELETE-Anweisung Zeilen aus einer Tabelle basierend auf angegebenen Bedingungen löschen. Eine häufige Situation besteht darin, Unterabfragen zum Definieren von Bedingungen zu verwenden. Es kann jedoch frustrierend sein, bei diesem Versuch auf Syntaxfehler zu stoßen.
Ein Benutzer hat versucht, mithilfe der folgenden Abfrage Zeilen aus der Tabelle term_hierarchy zu löschen:
<code class="language-sql">DELETE FROM term_hierarchy AS th WHERE th.parent = 1015 AND th.tid IN ( SELECT DISTINCT(th1.tid) FROM term_hierarchy AS th1 INNER JOIN term_hierarchy AS th2 ON (th1.tid = th2.tid AND th2.parent != 1015) WHERE th1.parent = 1015 );</code>
Dies führte jedoch zu folgendem Fehler:
<code>You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'AS th WHERE th.parent = 1015 AND th.tid IN ( SELECT DISTINCT(th1.tid) FROM ter' at line 1</code>
Das Problem hier ist eine Einschränkung von MySQL: Die zu löschende Tabelle (in diesem Fall term_hierarchy) darf nicht in einer Unterabfrage der Bedingung verwendet werden. Diese Einschränkung verhindert, dass Sie Tabellen in DELETE-Anweisungen selbstreferenzieren.
Lösung:
Um diese Einschränkung zu umgehen, können Sie eine verschachtelte Unterabfrage verwenden, die auf die Unterabfrage verweist, ohne die zu löschende Tabelle einzuschließen. Die folgende modifizierte Abfrage veranschaulicht dies:
<code class="language-sql">DELETE e.* FROM tableE e WHERE id IN (SELECT id FROM (SELECT id FROM tableE WHERE arg = 1 AND foo = 'bar') x);</code>
Durch das Einschließen einer Unterabfrage in eine andere Unterabfrage (in diesem Beispiel mit dem Namen x) kann MySQL Löschvorgänge ausführen, ohne die Selbstreferenzbeschränkung zu verletzen.
Das obige ist der detaillierte Inhalt vonWie verwende ich Unterabfragen in MySQL-DELETE-Anweisungen korrekt, um Syntaxfehler zu vermeiden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!