cari

Rumah  >  Soal Jawab  >  teks badan

mysql 删除重复记录出错?

语句:

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

该如何解决呢?

高洛峰高洛峰2948 hari yang lalu693

membalas semua(1)saya akan balas

  • 三叔

    三叔2016-11-08 09:40:51

    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)

    balas
    0
  • Batalbalas