mysql 删除重复记录出错?
高洛峰
高洛峰 2016-11-08 09:40:31
0
1
694

语句:

DELETE FROM price_monitor  WHERE EXISTS (SELECT 1 FROM price_monitor b WHERE b.domain = price_monitor.domain );

报错:

#1093 - You can't specify target table 'price_monitor' for update in FROM clause

该如何解决呢?

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

membalas semua(1)
三叔
DELETE FROM price_monitor WHERE id NOT IN (
    SELECT * FROM (
        SELECT MAX(id) FROM price_monitor  GROUP BY domain
    )
    as tmp
)

根据你的表字段替换上面的id。 如果要保留id最小的数据, 就把MAX(ID)改成MIN(id)

Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan