MySQL表rename引起外键问题解析
admin
2023-04-19 01:42:57
0

本文主要给大家介绍MySQL表rename引起外键问题解析,其所涉及的东西,从理论知识来获悉,有很多书籍、文献可供大家参考,从现实意义角度出发,累计多年的实践经验可分享给大家。

背景:
由于zabbix监控的问题图形展示很慢,对zabbix 库的events表进行了清理,清理过程采用了原表rename成bak表,重建events表后,将备份表部分数据导入到新表中。

后发现zabbix平台无法报警,无法恢复报警,日志类似报错:
 2315:20190301:104933.609 [Z3005] query failed: [1452] Cannot add or update a child row: a foreign key constraint fails (`zabbix`.`event_recovery`, CONSTRAINT `c_event_recovery_1` FOREIGN KEY (`eventid`) REFERENCES `events_bak20190225` (`eventid`) ON DELETE CASCADE) [insert into event_recovery (eventid,r_eventid,correlationid,c_eventid,userid) values (4242559,4242581,null,null,null),(4242561,4242580,null,null,null),(4242447,4242580,null,null,null);

原来rename后,关联的外键表的约束竟然一并修改成了归档表的关联。
处理方法如下:
查看哪些表建立外键时关联了归档表

MySQL表rename引起外键问题解析

select  distinct TABLE_NAME,CONSTRAINT_NAME,REFERENCED_TABLE_NAME from INFORMATION_SCHEMA.KEY_COLUMN_USAGE where TABLE_SCHEMA  ='zabbix' and CONSTRAINT_name != 'PRIMARY' and REFERENCED_TABLE_NAME like 'event%';
+----------------+--------------------+-----------------------+
| TABLE_NAME     | CONSTRAINT_NAME    | REFERENCED_TABLE_NAME |
+----------------+--------------------+-----------------------+
| acknowledges   | c_acknowledges_2   | events                |
| alerts         | c_alerts_2         | events                |
| alerts         | c_alerts_5         | events                |
| event_recovery | c_event_recovery_1 | events                |
| event_recovery | c_event_recovery_2 | events                |
| event_recovery | c_event_recovery_3 | events                |
| event_tag      | c_event_tag_1      | events_bak20190225    |
| problem        | c_problem_1        | events                |
| problem        | c_problem_2        | events                |
+----------------+--------------------+-----------------------+

查看表结构:

show create table event_tag\G
*************************** 1. row ***************************
       Table: event_tag
Create Table: CREATE TABLE `event_tag` (
  `eventtagid` bigint(20) unsigned NOT NULL,
  `eventid` bigint(20) unsigned NOT NULL,
  `tag` varchar(255) NOT NULL DEFAULT '',
  `value` varchar(255) NOT NULL DEFAULT '',
  PRIMARY KEY (`eventtagid`),
  KEY `event_tag_1` (`eventid`),
  CONSTRAINT `c_event_tag_1` FOREIGN KEY (`eventid`) REFERENCES `events_bak20190225` (`eventid`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8

修改外键约束:

alter table event_tag drop FOREIGN KEY  c_event_tag_1;
alter table event_tag add FOREIGN KEY  c_event_tag_1 (`eventid`) REFERENCES `events`(`eventid`) ON DELETE CASCADE;

zabbix好多外键,下次清理数据直接删除吧。

看了以上MySQL表rename引起外键问题解析介绍,希望能给大家在实际运用中带来一定的帮助。本文由于篇幅有限,难免会有不足和需要补充的地方,大家可以继续关注行业资讯板块,会定期给大家更新行业新闻和知识,如有需要更加专业的解答,可在官网联系我们的24小时售前售后,随时帮您解答问题的。

 

相关内容

热门资讯

玩家攻略科普“青松游戏辅助器?... 有 亲,根据资深记者爆料青松游戏是可以开挂的,确实有挂(咨询软件无需打开...
玩家攻略科普“闽游麻将拼多多辅... 您好:闽游麻将拼多多这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这...
重磅消息“新超圣炸/金/花怎么... 重磅消息“新超圣炸/金/花怎么开挂?”(太坑了果然有挂)您好,新超圣炸/金/花这个游戏其实有挂的,确...
终于了解“精品乐清麻将究竟有挂... 终于了解“精品乐清麻将究竟有挂吗?”(透视曝光猫腻)您好,精品乐清麻将这个游戏其实有挂的,确实是有挂...
玩家攻略科普“皇豪众娱真的有挂... 您好:皇豪众娱这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
今日重磅消息“道游联盟炸/金/... 您好:道游联盟炸/金/花这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家...
河南省2025年度1518名“... 【大河财立方消息】12月29日,中共河南省委组织部、河南省科学技术厅、河南省教育厅联合发布通知称,经...
玩家攻略科普“hhpoker开... 网上科普关于“hhpoker有没有挂”话题很是火热,小编也是针对hhpoker作*弊开挂的方法以及开...
AI“造富”5000亿美元后,... 【环球时报综合报道】英国《金融时报》26日报道称,综合梳理多个全球财富统计平台的数据发现,过去一年来...
玩家分享攻略“成就联盟到底有挂... 有 亲,根据资深记者爆料成就联盟是可以开挂的,确实有挂(咨询软件无需打开...