记一次业务中的大坑-MYSQL有重复数据下的增加主键

业务过程中,两张表求差

一开始一张小表,以为数据量不会很大,所以就没有做索引。
当实际运行过程中,小表慢慢长大了,发现两张表求差的时间能达到几个小时!!!AMAZING!
咋办,建索引呗
然后问题出现了,小表有重复数据,咋整,一个一个删除太sb了
写sql
DELETE FROM solr_indexed_max_incidentID WHERE incidentID IN (SELECT incidentID FROM solr_indexed_max_incidentID GROUP BY incidentID HAVING count(incidentID) > 1);
报错啦:
ERROR 1093 (HY000): You can't specify target table 'solr_indexed_max_incidentID' for update in FROM clause
呵呵,不行
另想辙

先建一个临时表,把去重后的数据烤过来
create table solr_tmp as SELECT * FROM solr_indexed_nax_incidentID GROUP BY incidentID HAVING count(incidentID) > 1;

然后把原表删了
drop table solr_indexed_max_incidentID;(后来想到这样做太不专业,应该把这个表改个名字相当于备份在那儿,万一下一步出错了不懵逼了?)

然后改名字
RENAME TABLE solr_tmp TO solr_indexed_max_incidentID;

然后加索引
alter table 'solr_indexed_max_incidentID' add primary key('incidentID');

继续运行业务逻辑,几秒钟求差完成!

转载于:https://www.cnblogs.com/loveling-0239/p/8087317.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值