ホームページ  >  記事  >  データベース  >  innodb_index_stats がデータをインポートするときにテーブルの主キーの競合を促すエラーの詳細な説明

innodb_index_stats がデータをインポートするときにテーブルの主キーの競合を促すエラーの詳細な説明

Y2J
Y2Jオリジナル
2017-05-24 13:40:432777ブラウズ

次のエディターは、innodb_index_stats がバックアップ データをインポートする際のテーブルの主キーの競合の問題を解決する方法に関する記事を提供します。編集者はこれがとても良いものだと思ったので、皆さんの参考として今から共有します。エディターをフォローして一緒に見てみましょう

障害の説明

percona5.6、mysqldumpフルバックアップ、バックアップデータインポート時のエラー キー「PRIMARY」のエントリ「hoc_log99-item_log_27-PRIMARY-n_diff_pfx01」が重複しています

失敗の原因

主キーが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のバグ、他の同僚もそれに遭遇しています同じエラー

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 バックアップ ファイル内のこのテーブルの挿入を replace に変更します

3 mysql -f 強制インポート

【関連する推奨事項】

1. Mysql の無料ビデオチュートリアル

2. MySQL での新しいユーザー権限の追加の詳細な例

3. MySQL でのパスワードとアクセス制限の変更の詳細な例

4 正規表現を使用してデータベース内のコンテンツを置換する詳細な例 解決策

5. mysqlに画像を保存するphpの例を詳しく解説

以上がinnodb_index_stats がデータをインポートするときにテーブルの主キーの競合を促すエラーの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。