innodb_index_stats导入备份数据时报错表主键冲突
2016-10-08 18:43
465 查看
故障描述
percona5.6,mysqldump全备份,导入备份数据时报错Duplicate entry 'hoc_log99-item_log_27-PRIMARY-n_diff_pfx01' for key 'PRIMARY'故障原因
查看了下这个主键应该是mysql系统库下的系统表innodb_index_statsmysql> show create table innodb_index_stats\G
*************************** 1. row ***************************
Table: innodb_index_stats
Create Table: CREATE TABLE `innodb_index_stats` (
`database_name` varchar(64) COLLATE utf8_bin NOT NULL,
`table_name` varchar(64) COLLATE utf8_bin NOT NULL,
`index_name` varchar(64) COLLATE utf8_bin NOT NULL,
`last_update` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`stat_name` varchar(64) COLLATE utf8_bin NOT NULL,
`stat_value` bigint(20) unsigned NOT NULL,
`sample_size` bigint(20) unsigned DEFAULT NULL,
`stat_description` varchar(1024) COLLATE utf8_bin NOT NULL,
PRIMARY KEY (`database_name`,`table_name`,`index_name`,`stat_name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin STATS_PERSISTENT=0
1 row in set (0.00 sec)
mysql> select * from innodb_index_stats where database_name='hoc_log99' and table_name='item_log_27' and stat_name='n_diff_pfx01' and index_name='PRIMARY';
+---------------+-------------+------------+---------------------+--------------+------------+-------------+------------------+
| database_name | table_name | index_name | last_update | stat_name | stat_value | sample_size | stat_description |
+---------------+-------------+------------+---------------------+--------------+------------+-------------+------------------+
| hoc_log99 | item_log_27 | PRIMARY | 2016-10-07 18:44:06 | n_diff_pfx01 | 823672 | 20 | redid |
+---------------+-------------+------------+---------------------+--------------+------------+-------------+------------------+
1 row in set (0.00 sec)
再查看下我当时的备份文件sql的记录,发现再导入这个表之前是会重建表的,排除了再导入这个表之前,有item_log_27 表的操作记录进了innodb_index_stats的可能。
-- Table structure for table `innodb_index_stats`
DROP TABLE IF EXISTS `innodb_index_stats`;
CREATE TABLE `innodb_index_stats` (
-- Dumping data for table `innodb_index_stats`
LOCK TABLES `innodb_index_stats` WRITE;
/*!40000 ALTER TABLE `innodb_index_stats` DISABLE KEYS */;
于是我又查看了下最近的binlog记录,发现确实有重建这个表的操作
DROP TABLE IF EXISTS `innodb_index_stats` /* generated by server */
CREATE TABLE `innodb_index_stats` (
/*!40000 ALTER TABLE `innodb_index_stats` DISABLE KEYS */
结论
mysql 5.6的bug,也有其他同行遇到了一样的错误https://www.percona.com/forums/questions-discussions/mysql-and-percona-server/31971-mysql-innodb_index_stats-duplication-entry-error-on-restore https://bugs.mysql.com/bug.php?id=71814
解决办法
1 mysqldump添加参数忽略这个表的备份2 将备份文件中的这个表的insert改为replace
3 mysql -f强制导入
相关文章推荐
- innodb_index_stats导入备份数据时报错表主键冲突的解决方法
- Oracle的imp命令导入备份数据
- ORACLE小经验积累——OMS SERVER的安装与配置(用于数据备份、导入/导出等操作)
- Linux环境中Oracle数据导入与导出备份创建用户操作
- mysql的数据备份和导入
- oracle数据备份导出导入
- Oracle数据库数据导入导出基本方法及unix定时备份脚本
- oralce9i备份的数据导入到oralce10g中的过程
- Oracle 数据导入和导出(备份和恢复) 常用命令
- MySQL数据的导出和导入工具:mysqldump(备份数据库的命令)
- 一次大批量数据备份和导入工作
- SQL Server导入、导出、备份数据方法
- SQL Server导入、导出、备份数据方法
- Linux环境中Oracle数据导入与导出备份创建用户操作
- PostgreSQL数据库导入备份数据
- Linux环境中Oracle数据导入与导出备份操作
- 通过批处理来完成oracle的数据导入导出及备份工作
- 重装系统 Outlook和Onenote的数据备份与导入
- oracle数据库备份(2)——Oracle 的数据导出导入命令:exp、imp
- db2导入导出单表数据 db2备份恢复