加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

添加外键时在mysql中死锁

发布时间:2021-02-24 22:56:00 所属栏目:编程 来源:网络整理
导读:我们的数据库中有一个名为company_competitors的表.有一项事变天天城市对其举办截断和加载. 该表有两列company_id和competitor_id都引用另一个表公司. CREATE TABLE `company_competitors` ( `id` bigint(20) NOT NULL AUTO_INCREMENT,`company_id` int(11)

我们的数据库中有一个名为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表现全部查询,嗣魅正在守候获取元数据锁,我必需终止全部选择查询,以便外键添加完成.

我必要辅佐来相识此处呈现僵局的缘故起因以及如那里理赏罚它.我也想听听是否有更好的要领来截断和加载零停机时刻.

最佳谜底 就小我私人而言,假如很少产生僵局,我只是一再执行新买卖营业并从头启动
查询(这不是最好的办理方案,但在这种环境下有用).
可是,假如您提到的僵局看起来像僵直,您可以搜查更多
?行使呼吁SHOW ENGINE INNODB STATUS来获守信息,以查察最近的死锁的一些具体信息.
我的提议照旧将建设company_competitors_new的块放在

SET foreign_key_checks = 0;

…(查询)…

SET foreign_key_checks = 1;

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读