解决Mysql中删除重复记录的问题

题记

本文主要介绍Mysql数据库表中,如何删除相同索引值、更新日期较早的记录行。

1、相同记录的由来

以Mysql为例,根据表的设计原则,表中不可能存在两条完全相同的记录。

第一范式(1NF):字段值具有原子性,不能再分(所有关系型数据库系统都满足第一范式); 
例如:姓名字段,其中姓和名是一个整体,如果区分姓和名那么必须设立两个独立字段;

第二范式(2NF):一个表必须有主键,即每行数据都能被唯一的区分;  
(备注:必须先满足第一范式;) 

第三范式(3NF):一个表中不能包涵其他相关表中非关键字段的信息,即数据表不能有沉余字段;( 备注:必须先满足第二范式;)

但是,在我们实际的业务系统中,很大可能会存在,除了主键外,剩余列完全相同或部分核心字段完全相同的数据在同一个库表中存在。

举例,如下截图所示:
这里写图片描述
该表中,主键为第1列ID和第2列Wid,两行数据的仅更新日期和标记列(2,3)不同,剩余列完全相同。
随着记录的增多,我们检索的需要,仅需要将Mid相同的记录保留住更新日期最新的一条记录。

2、如何仅保留最新日期的一条记录,删除其余日期较早的相同Wid的记录?

以下是删除操作sql的分解操作步骤。

步骤1:找出重复的记录。

select wid from   search_dispos_copy group by wid having count(wid) > 1;

步骤2:找出重复记录中,区分标志字段的最大值。

select max(update_time) from   search_dispos_copy group by article_id having count(wid )>1;

步骤3:查询出重复记录的ID信息。

select id, wid, update_time from search_dispos_copy
where wid in (select wid from search_dispos_copy group by wid having count(wid) > 1)
and update_time not in (select max(update_time) from search_dispos_copy group by wid having count(wid )>1);
order by wid;

步骤4:删除对应的ID记录。

整理出id信息,以逗号分隔,id是唯一值

1)删除空行操作

sed -i ‘/^$/d’ ./id_list.txt

2)换行符转化为逗号

cat id_list.txt | tr “\n” “,” > id_list_a.txt

3)删除操作

delete from msearch_dispose_articles_copy where id in ();
()里面放入4.2中 list_a存储的记录即可。

3、讨论

为了标注一条记录的状态,设计的时候我们会关联库表中的一条记录。但这条记录在库表中是唯一的,标注状态的改变体现在表中是相同记录行的某一特征列的改变。
因此,我们要做的是更新记录,而不是再次插入操作。
这样,也就避免了出现1中的“相同记录”。

20170309 22:18 于家中床前

作者:铭毅天下
转载请标明出处,原文地址:
http://blog.csdn.net/laoyang360/article/details/60976978
如果感觉本文对您有帮助,请点击‘顶’支持一下,您的支持是我坚持写作最大的动力,谢谢!

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

铭毅天下

和你一起,死磕Elastic!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值