innodb_index_stats导入备份数据时报错表主键冲突的解决方法

作者:jingxian 时间:2024-01-19 19:33:51 

故障描述

percona5.6,mysqldump全备份,导入备份数据时报错Duplicate entry 'hoc_log99-item_log_27-PRIMARY-n_diff_pfx01' for key 'PRIMARY'

故障原因

查看了下这个主键应该是MySQL系统库下的系统表innodb_index_stats


mysql> 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
0
投稿

猜你喜欢

  • 网页布局设计基础

    2008-10-16 13:58:00
  • 用层模拟下拉列表框

    2013-07-01 01:19:00
  • PHP count()函数讲解

    2023-06-04 11:46:41
  • python多进程 主进程和子进程间共享和不共享全局变量实例

    2022-11-05 11:42:56
  • Golang如何交叉编译各个平台的二进制文件详解

    2024-05-22 17:48:47
  • python编写脚本之pyautogui的安装和使用教程

    2021-06-17 09:48:11
  • Linux下设置每天自动备份数据库的方法

    2024-01-24 02:45:31
  • Python实现在Linux系统下更改当前进程运行用户

    2023-03-27 02:53:33
  • Go语言并发爬虫的具体实现

    2024-02-22 10:35:31
  • JavaScript实现大文件上传的示例代码

    2024-05-28 15:40:23
  • Orcale权限、角色查看创建方法

    2024-01-20 04:22:02
  • Django 实现xadmin后台菜单改为中文

    2021-12-28 10:31:49
  • pytorch中的卷积和池化计算方式详解

    2021-03-31 19:26:32
  • SQL Server CROSS APPLY和OUTER APPLY的应用详解

    2024-01-21 02:27:21
  • python删除某个目录文件夹的方法

    2022-08-22 06:33:32
  • asp三天学好ADO对象之第二天

    2008-10-09 12:49:00
  • Oracle数据库性能优化技术开发者网络Oracle

    2010-07-18 13:05:00
  • Go语言基础数组用法及示例详解

    2024-04-26 17:33:52
  • Keras设定GPU使用内存大小方式(Tensorflow backend)

    2021-12-20 22:15:12
  • Mysql分库分表之后主键处理的几种方法

    2024-01-20 21:00:09
  • asp之家 网络编程 m.aspxhome.com