You can't specify target table 'e' for update in FROM clause
UPDATE emp e SET e.salary=e.salary+7 WHERE e.id IN(SELECT e1.id FROM emp e1,dept d WHERE e1.dep_id=d.id AND d.name='开发一部' AND e1.salary<2000);
不能先select出同一表中的某些值,再update这个表(在同一语句中)。
在mysql 中会出现这个问题。
改写:
UPDATE emp e SET e.salary=e.salary+7 WHERE e.id IN(
SELECT w.* FROM(
SELECT e1.id FROM emp e1,dept d WHERE e1.dep_id=d.id AND d.name='开发一部' AND e1.salary<2000
) w
);