测试的时候数据库外键导致死锁_添加外键时在mysql中死锁

我们的数据库中有一个名为company_competitors的表.有一项工作每天都会对其进行截断和加载.

该表有两列company_id和competitor_id都引用另一个表公司.

CREATE TABLE `company_competitors` (

`id` bigint(20) NOT NULL AUTO_INCREMENT,`company_id` int(11) DEFAULT NULL,`competitor_id` int(11) DEFAULT NULL,PRIMARY KEY (`id`),CONSTRAINT `fk_rails_company_id_c1ac450a` FOREIGN KEY (`company_id`) REFERENCES `companies` (`id`),CONSTRAINT `fk_rails_competitor_id_772a45c6` FOREIGN KEY (`competitor_id`) REFERENCES `companies` (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=268477 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin

截断和加载中包括的步骤是:

>创建一个新表company_competitors_new

>在两列(company_id,competitor_id)上一一添加外键约束.

>将数据加载到新表中.

>交换表company_competitors和company_competitors_new.

查询:

“创建表company_competitors_new LIKE company_competitors;

更改表company_competitors_new ADD CONSTRAINT fk_rails_company_id_53f8f57a外键(company_id)引用了company(id);’

在添加外键时,其他人可能会访问company表.因此,当第二个查询运行时,数据库陷入死锁,并且对company表的任何查询都不会执行.

show full processlist显示所有查询,说正在等待获取元数据锁,我必须终止所有选择查询,以便外键添加完成.

我需要帮助来了解此处出现僵局的原因以及如何处理它.我也想听听是否有更好的方法来截断和加载零停机时间.

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值