DELETE 文の複合テーブル構文
必要があったので、MySQL の DELETE 文で、複合テーブル構文ってのを調べた。例えばこんなん。
DELETE dept, emp FROM dept LEFT JOIN emp ON dept.deptno = emp.deptno WHERE dept.deptno = 20;
例は Oracle のサンプルデータベース SCOTT のものだが、何らかの理由で SCOTT さんの会社から RESERCH 部がなくなって、その部署の従業員も一斉解雇になったらしい。SCOTT さんもクビで、愛猫 TIGER 君とともに路頭に迷うことに。それをこの DELETE 文一発でデータベースに反映することができる。
あるいは
DELETE sub FROM emp boss LEFT JOIN emp sub ON boss.empno = sub.mgr WHERE boss.empno IN (7698, 7902)
何があったのかはわからないが、BLAKE 氏と FORD 氏の部下を全員削除する。この例は DELETE 句では FROM 句で指定した別名が使用でき、FROM 句で指定した表のうち一部の表のみを削除できることを示している。条件が複雑な場合に便利。他の RDBMS にもこういう構文あったっけな ?
Oracle の SCOTT データベースが分かんない人のために、EMP 表と DEPT 表のみ MySQL 用の DDL をのっけておきます。