婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > innodb_index_stats導入備份數據時報錯表主鍵沖突的解決方法

innodb_index_stats導入備份數據時報錯表主鍵沖突的解決方法

熱門標簽:昆明智能外呼系統中心 地圖標注培訓 電銷機器人說明書 電銷機器人公眾號推送 智能電銷機器人靠譜么 南宋地圖標注黃河華山 安國在哪里辦理400電話 手機用地圖標注工具 長安區違法建房地圖標注

故障描述

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導入備份數據時報錯表主鍵沖突的解決方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

標簽:吉安 江門 東莞 潛江 長沙 合肥 武漢 南昌

巨人網絡通訊聲明:本文標題《innodb_index_stats導入備份數據時報錯表主鍵沖突的解決方法》,本文關鍵詞  innodb,index,stats,導入,備份,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《innodb_index_stats導入備份數據時報錯表主鍵沖突的解決方法》相關的同類信息!
  • 本頁收集關于innodb_index_stats導入備份數據時報錯表主鍵沖突的解決方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 衡阳市| 汤阴县| 盐城市| 镇远县| 革吉县| 东阳市| 手机| 象山县| 上蔡县| 称多县| 封丘县| 肥乡县| 绥江县| 兴文县| 油尖旺区| 蓬安县| 中西区| 黔江区| 会泽县| 梅河口市| 九龙城区| 巴青县| 新和县| 阿尔山市| 德保县| 永善县| 舞钢市| 友谊县| 泽普县| 西城区| 寿阳县| 监利县| 咸宁市| 会东县| 鹿泉市| 三台县| 仁布县| 高清| 乌鲁木齐县| 中阳县| 浦城县|