mysql删除表中的重复行并保留id较小(或者较大)记录

2018-10-1109:31:55数据库教程Comments3,173 views字数 1195阅读模式

实际录入数据库的过程中,如果数据量比较大的话,难免会因为一些原因,而录入多条重复的记录,那么应该如何操作才能删除重复行,并且保留一条id较大,或者较小的记录呢。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

在本例中所用数据表结构如下所示tdb_goods文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

mysql删除表中的重复行并保留id较小(或者较大)记录文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

表中数据重复如图所示文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

mysql删除表中的重复行并保留id较小(或者较大)记录文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

首先第一步,利用group by分组查出每组中数目大于2的(即重复记录的)内容文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

  1. mysql> SELECT goods_id,goods_name FROM tdb_goods GROUP BY goods_name HAVING COUN
  2. T(goods_name)>=2;
  1. +----------+------------------------------+
  2. | goods_id | goods_name |
  3. +----------+------------------------------+
  4. | 20 | X3250 M4机架式服务器 2583i14 |
  5. | 19 | 商务双肩背包 |
  6. -------------------------------------------

然后使用LEFT JOIN使原始表和上述查询结果进行连接,删除重复记录,保留id较小的记录文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

  1. mysql> DELETE t1 FROM tdb_goods AS t1 LEFT JOIN( SELECT goods_id,goods_name FROM
  2. tdb_goods GROUP BY goods_name HAVING COUNT(goods_name)>=2) AS t2 ON t1.goods_na
  3. me = t2.goods_name WHERE t1.goods_id>t2.goods_id;

从上述语句可以看出,条件是名称相同的,然后删除所有goods_id大的记录。这样就可以实现想要的效果。
如果想保留id较大的同理,如下所示文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

  1. mysql> DELETE t1 FROM tdb_goods AS t1 LEFT JOIN( SELECT max(goods_id) AS goods_i
  2. d,goods_name FROM tdb_goods GROUP BY goods_name HAVING COUNT(goods_name)>=2) AS
  3. t2 ON t1.goods_name = t2.goods_name WHERE t1.goods_id<t2.goods_id;
  4. Query OK, 2 rows affected (0.03 sec)

下边记录一下我使用过的sql语句:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html

  1. SELECT uid,id,username FROM qs_member GROUP BY username HAVING COUNT(username)>=2;
  1. DELETE t1 FROM qs_member AS t1 LEFT JOIN( SELECT uid,username FROM qs_member GROUP BY username HAVING COUNT(username)>=2) AS t2 ON t1.username = t2.username WHERE t1.uid>t2.uid;
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/6525.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/sjk/6525.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定