Instruction MySQL DELETE utilisant une sous-requête comme condition
Dans MySQL, l'instruction DELETE vous permet de supprimer des lignes d'une table en fonction de conditions spécifiées. Une situation courante consiste à utiliser des sous-requêtes pour définir des conditions. Cependant, il peut être frustrant de rencontrer des erreurs de syntaxe en essayant de procéder ainsi.
Un utilisateur a tenté de supprimer des lignes de la table term_hierarchy à l'aide de la requête suivante :
<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>
Cependant, cela a entraîné l'erreur suivante :
<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>
Le problème ici est une limitation de MySQL : la table en cours de suppression (term_hierarchy dans ce cas) ne peut pas être utilisée dans une sous-requête de la condition. Cette restriction vous empêche d'auto-référencer des tables dans les instructions DELETE.
Solution :
Pour contourner cette limitation, vous pouvez utiliser une sous-requête imbriquée qui référence la sous-requête sans inclure la table à supprimer. La requête modifiée suivante le démontre :
<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>
En encapsulant une sous-requête dans une autre sous-requête (nommée x dans cet exemple), MySQL peut effectuer des opérations de suppression sans violer la restriction d'auto-référence.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!