MySQL InnoDB row_id 境界オーバーフロー検証方法の手順

MySQL InnoDB row_id 境界オーバーフロー検証方法の手順

背景

クラスメートと row_id の境界問題について話し合ったので、ここで詳しく説明します。

InnoDB テーブルで主キーが定義されていない場合は、システムのデフォルトの増分 row_id (dict_sys->row_id) が主キーとして使用されます。行が挿入されるたびに 1 を追加し、最大値に達するまでこのプロセスを繰り返します。

dict_sys->row_id は unsigned long long として定義されていますが、この主キー値は 6 バイトしかないため、最大値は 2^48 になることに注意してください。 row_id がこの値を超えると、値は増加しますが、書き込み時に下位ビットのみが取得され、モジュロ演算と見なすことができます。

質問

これには問題があります。長時間実行される MySQL では、行が頻繁に挿入および削除される場合 (ログ テーブルなど)、最終的なテーブル サイズがそれほど大きくなくても、row_id 値の再利用が発生する可能性があります。また、主キー値であるため、繰り返すことはできないこともわかっています。

次のようなことが起こったとします。テーブルで、新しく挿入された行の row_id が古い行の row_id と競合します。何が起こるでしょうか?

確認する

実際、ここで必要な結論は 1 つだけです。この記事の目的は、検証方法について議論することです。上記の情報を基に、次の再現手順の設計を検討できます。

1) 主キーのない空のテーブルを作成する

2) gdbはdict_sys->row_idを1に設定する

3) 空のテーブルに複数の行を挿入する

4) gdbはdict_sys->row_idを2^48に設定する

5) さらに数行挿入する

6) 結果を見る

結論は

ご覧のとおり、行 (1) と (2) は上書きされています。

より合理的な解決策は、MySQL テーブルの自動インクリメント主キーと同様に、重複キー エラーを報告することです。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • Mysql InnoDBとMyISAMの違いの分析
  • MySQL innodb B+ツリーの高さを取得する方法
  • MySQL MyISAM と InnoDB の違い
  • MySQL InnoDBストレージエンジンについて簡単に説明します
  • MySQL Innodb ストレージ構造と Null 値の保存の詳細な説明
  • MySQL InnoDB のトランザクション特性を確保するにはどうすればよいですか?
  • MySQL 起動エラー InnoDB: ロックできません/ibdata1 エラー
  • MySQL InnoDB のロック機構の詳細な説明
  • MySQL (InnoDB) がデッドロックを処理する方法の詳細な説明
  • MySQL 学習 (VII): Innodb ストレージ エンジン インデックスの実装原理の詳細説明
  • MySQL slow_log テーブルを InnoDB エンジンに変更することはできません。詳細な説明
  • MySQL InnoDB の重要なコンポーネントの概要

<<:  キープアライブキャッシュをクリアする方法の詳細なグラフィック説明

>>:  Vue でキープアライブを使用した後にキャッシュをクリアする方法

推薦する

Ubuntu 16.04 mysql5.7.17 リモートポート 3306 を開く

MySQLへのリモートアクセスを有効にするデフォルトでは、MySQL ユーザーにはリモート アクセス...

MySQL 5.7.21 履歴データディレクトリからデータを復元するチュートリアルの解凍バージョン

状況の説明: データベースが異常に起動およびシャットダウンしたため、サービスを再度起動したときに「起...

Select はダブルクリック dbclick イベントをサポートしていません

XML/HTML コードコンテンツをクリップボードにコピー< div クラス= "c...

JavaScript の基本演算子

目次1. オペレーター要約する1. オペレーター演算子は、代入、比較、算術演算などの機能を実装するた...

ローカルストレージにブール型の値を保存する際の落とし穴を解決する

LocalStorageはブール値を保存します今日、ブール値データを保存するために localsto...

MySQL 8.0.21.0 コミュニティ エディションのインストール チュートリアル (詳細な図解)

1. MySQLをダウンロードするMySQL 公式 Web サイトにログインし、MSI インストー...

背景画像に CSS3 変換を適用するためのソリューション

CSS 変換は便利ですが、背景画像にはまだ適用されていません。この投稿では、背景画像を回転させたい場...

MySQL で JSON 形式のフィールドをクエリする詳細な説明

作業開発プロセス中に、顧客の名前、携帯電話番号、ID カード、およびドキュメントの種類を動的に保存す...

MySQL でテーブルデータをクリアする 2 つの方法とその違い

MySQL でデータを削除するには 2 つの方法があります。切り詰めは大まかな伐採の一種である削除は...

Vueはチャットインターフェースを実装する

この記事の例では、チャットインターフェースの表示を実現するためのVueの具体的なコードを参考までに共...

入力タイプとは何を意味し、入力を制限する方法

入力を制限する一般的な方法1. ボタンが押されたときに点線のボックスを消すには、入力に属性値hide...

Dockerを使用して外部からアクセス可能なMySQLを構築する詳細な説明

MySQL 8.0をインストールする docker run -p 63306:3306 -e MYS...

純粋なCSSでは、子要素が親要素の幅制限を突破できる。

文章のスタイルでは、このような状況がよく見られます コードは次のとおりです <div styl...

Linux で jar パッケージを起動してバックグラウンドで実行する方法

jar パッケージを実行する Linux コマンドは次のとおりです。方法1: java -jar s...

MySQL サブクエリとグループ化されたクエリ

目次概要サブクエリサブクエリの分類クエリの結果によるとサブクエリの位置で区別する選択後のサブクエリサ...