码迷,mamicode.com
首页 > 数据库 > 详细

MySQL 删除重复数据实例

时间:2018-05-18 13:46:20      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:bsp   rom   sel   存在   class   into   保留   art   sele   

如何删除重复数据

 

业务场景:删除评论表中对同一订单同一商品的重复评论,只保留最早的一条。

  1. 查看是否存在对于同一订单同一商品的重复评论。

 

SELECT order_id,product_id,COUNT(*) FROM product_comment GROUP BY order_id,product_id HAVING COUNT(*)>1;

 

  1. 备份product_comment表。
CREATE TABLE bak_product_comment_18051801 LIKE product_comment;

INSERT INTO bak_product_comment_18051801 SELECT * FROM product_comment;

 

  1. 删除同一订单的重复评论。
DELETE a
FROM product_comment a
JOIN(
    SELECT order_id,product_id,MIN(comment_id) AS comment_id
    FROM product_comment
    GROUP BY order_id,product_id
    HAVING COUNT(*)>=2
) b ON a.order_id=b.order_id AND a.product_id=b.product_id
AND a.comment_id>b.comment_id

 

MySQL 删除重复数据实例

标签:bsp   rom   sel   存在   class   into   保留   art   sele   

原文地址:https://www.cnblogs.com/yizhiamumu/p/9055119.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!