<form id="hz9zz"></form>
  • <form id="hz9zz"></form>

      <nobr id="hz9zz"></nobr>

      <form id="hz9zz"></form>

    1. 明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

      詳細說明innodb_index_stats導入數據時提示表主鍵沖突的出錯

      [摘要]下面小編就為大家帶來一篇innodb_index_stats導入備份數據時報錯表主鍵沖突的解決方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧故障描述percona5.6,mysqldump全備份,導入備份數據時報錯Duplicate entry hoc_log9...
      下面小編就為大家帶來一篇innodb_index_stats導入備份數據時報錯表主鍵沖突的解決方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

      故障描述

      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,也有其他同行遇到了一樣的錯誤

      www.percona.com/forums/questions-discussions/mysql-and-percona-server/31971-mysql-innodb_index_stats-duplication-entry-error-on-restore

      bugs.mysql.com/bug.PHP?id=71814

      解決辦法

      1 mysqldump添加參數忽略這個表的備份

      2 將備份文件中的這個表的insert改為replace

      3 mysql -f強制導入

      【相關推薦】

      1. Mysql免費視頻教程

      2. MySQL中添加新用戶權限的實例詳解

      3. MySQL修改密碼和訪問限制的實例詳解

      4. 用正則表達式替換數據庫中的內容的實例詳 解

      5. php將圖片儲存mysql中的實例詳解

      以上就是詳解innodb_index_stats導入數據時提示表主鍵沖突的錯誤的詳細內容,更多請關注php中文網其它相關文章!


      學習教程快速掌握從入門到精通的SQL知識。




      日韩精品一区二区三区高清