【问题标题】:Delete with table alias in Mysql在 Mysql 中使用表别名删除
【发布时间】:2012-07-30 23:39:57
【问题描述】:

我正在尝试删除 mysql 5.1 表中的重复行

查询是

delete from sessions o where exists (select * from sessions i where i.data=o.data and i.id<>o.id);

但它似乎不起作用,我读到在 mysql 中使用表别名来删除语句是不可能的,但这如何:Deleting Records 工作?

【问题讨论】:

  • “它似乎不起作用”不是一个有效的解释。您收到的错误信息是什么?
  • @Jocelyn: ERROR 1064 (42000): 你的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行的 'c1 where exists (select * from sessions i)' 附近使用正确的语法

标签: mysql innodb


【解决方案1】:

试试这个查询 -

DELETE t1 FROM sessions t1
  JOIN (SELECT data, MIN(id) id FROM sessions GROUP BY data) t2
    ON t1.id <> t2.id AND t1.data = t2.data;

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-10-29
    • 1970-01-01
    • 1970-01-01
    • 2018-06-19
    • 1970-01-01
    • 2010-10-13
    相关资源
    最近更新 更多