记一次删千万级表数据

        今天测试突然找到我说,点个按钮要等很久很久,赶紧排查问题。反复试了下,刚开始等很长时间还可以执行成功,后面直接报Lock wait timeout exceeded; try restarting transaction,在网上看是因为锁超时导致释放锁,那还是要找下根源呀,毕竟之前都能运行的好好的~

        看代码一层层分析,刚开始猜想是不是因为最近测试环境的库换成了正式环境的库数据,而正式库表有千万条,点这个按钮每次都要去删这个千万条表数据没走索引导致,后来把这个删除sql拿去一分析,哦吼,虽然sql是用到表索引,但还是走的全表扫描,在网上翻了很久,最后还是考虑直接用id主键去删除,果然速度杆杆的~~

        不知道什么原因导致已经用了表索引而还是全表扫描,等以后有经验再慢慢研究下~~~

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值