• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

mysql 搞代码 4年前 (2022-01-09) 19次浏览 已收录 0个评论

在实际录入数据库的过程中,如果数据量比较大的话,难免会因为一些原因,而录入多条重复的记录,那么应该如何操作才能删除重复行,并且保留一条id较大,或者较小的记录呢。

在本例中所用数据表结构如下所示tdb_goods

表中数据重复如图所示

首先第一步,利用group by分组查出每组中数目大于2的(即重复记录的)内容

mysql> SELECT goods_id,goods_name FROM tdb_goods GROUP BY goods_name HAVING COUNT(goods_name)>=2;+----------+------------------------------+| goods_id | goods_name                   |+----------+------------------------------+|       20 | X3250 M4机架式服务器 2583i14            ||       19 | 商务双肩背包                          |+----------+------------------------------+2 rows in set (0.01 sec)

本文来源gaodai$ma#com搞$$代**码网$ 然后使用LEFT JOIN使原始表和上述查询结果进行连接,删除重复记录,保留id较小的记录

mysql> DELETE t1 FROM tdb_goods AS t1 LEFT JOIN( SELECT goods_id,goods_name FROM tdb_goods GROUP BY goods_name HAVING COUNT(goods_name)>=2) AS t2 ON t1.goods_name = t2.goods_name WHERE t1.goods_id>t2.goods_id;Query OK, 2 rows affected (0.06 sec)

从上述语句可以看出,条件是名称相同的,然后删除所有goods_id大的记录。这样就可以实现想要的效果。

如果想保留id较大的同理,如下所示

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

注关于表连接,如有疑问请查看JOIN的用法。

以上就是mysql如何删除表中的重复行并保留id较小(或者较大)的记录的内容,更多相关内容请关注搞代码(www.gaodaima.com)!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql如何删除表中的重复行并保留id较小(或者较大)的记录

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址