错误1093(HY000):您不能在FROM子句中更新目标表“a”。

3

我有一个查询

UPDATE trh_adminLoginDate SET superseded = true WHERE EXISTS 
 (SELECT * FROM trh_adminLoginDate AS a2 WHERE a2.adminId = a.adminId AND a2.loginDate > a.loginDate AND a2.clientPlatform = a.clientPlatform)

表格长这样。

+----------------+--------------+------+-----+---------+----------------+
| Field          | Type         | Null | Key | Default | Extra          |
+----------------+--------------+------+-----+---------+----------------+
| id             | bigint(20)   | NO   | PRI | NULL    | auto_increment |
| dateCreated    | datetime     | NO   |     | NULL    |                |
| version        | int(11)      | NO   |     | NULL    |                |
| dateModified   | datetime     | NO   |     | NULL    |                |
| adminId        | bigint(20)   | NO   | MUL | NULL    |                |
| clientPlatform | varchar(255) | YES  |     | NULL    |                |
| loginDate      | datetime     | YES  |     | NULL    |                |
| superseded     | tinyint(1)   | NO   |     | NULL    |                |
+----------------+--------------+------+-----+---------+----------------+
执行此查询时,我收到以下错误提示:
ERROR 1093 (HY000): You can't specify target table 'a' for update in FROM clause

我可以创建临时表,保存子查询的结果,然后执行UPDATE。但是我不想用这种方式。有人能建议我更好的做法吗?

2个回答

4
您正在使用别名“a”,但您从未定义它。 也许这样做可以解决问题:
UPDATE  trh_adminLoginDate a

        JOIN trh_adminLoginDate AS a2 
        ON a2.adminId = a.adminId 
        AND a2.loginDate > a.loginDate 
        AND a2.clientPlatform = a.clientPlatform

SET a.superseded = true

-1

或许这个可以解决问题:

UPDATE trh_adminLoginDate a

SET    superseded = true 

WHERE EXISTS 
      (SELECT * FROM trh_adminLoginDate WHERE adminId = a.adminId AND loginDate > a.loginDate AND clientPlatform = a.clientPlatform)

这个查询在SQL中可以工作,但在HQL上无法工作。您能否提供HQL版本? - Rakesh

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,