视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Mysql删除重复数据保留最小的id的解决方法
2020-11-09 20:30:17 责编:小采
文档


在网上查找删除重复数据保留id最小的数据,方法如下:

DELETE
FROM
 people
WHERE
 peopleName IN (
 SELECT
 peopleName
 FROM
 people
 GROUP BY
 peopleName
 HAVING
 count(peopleName) > 1
 )
AND peopleId NOT IN (
 SELECT
 min(peopleId)
 FROM
 people
 GROUP BY
 peopleName
 HAVING
 count(peopleName) > 1
)

自己使用的时候显示报错:

 delete from tb where id in (SELECT max(id) from tb GROUP BY user HAVING count(user)>1)

[Err] 1093 - You can't specify target table ‘XXX' for update in FROM clause

暂时不知道是什么原因导致的。

然后想办法分布操作,首先筛选出有重复user的数据,然后用max()选出其中较大的那一行:

SELECT max(id) from tb GROUP BY user HAVING count(user)>1

然后再根据得到的max(id)逐条删除多余的数据

delete from tb where id=xx

是个笨方法,暂时先解决问题吧。

总结

以上所述是小编给大家介绍的Mysql删除重复数据保留最小的id 的解决方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

您可能感兴趣的文章:

  • MySQL查询重复数据(删除重复数据保留id最小的一条为唯一数据)
  • MySQL根据某一个或者多个字段查找重复数据的sql语句
  • MySQL 去除重复数据实例详解
  • mysql查询表里的重复数据方法
  • mysql查找删除重复数据并只保留一条实例详解
  • Yii+MYSQL锁表防止并发情况下重复数据的方法
  • 很全面的MySQL处理重复数据代码
  • mysql查找删除表中重复数据方法总结
  • 下载本文
    显示全文
    专题