Mysql で自動増分主キー ID を更新するときに問題が発生しました

Mysql で自動増分主キー ID を更新するときに問題が発生しました

これは私が知っている問題ですが、私は罠に陥りそうになりました(忘れそうになりましたが、幸いにもオンライン前にオンラインポイントを整理したときに思い出しました)ので、ここに特別に記録しました

自動インクリメント ID を更新する理由は何ですか?

過去のビジネス上の問題により、ID のバッチを更新する必要があり、競合を避けるために、更新のために ID を数倍に拡張する必要がありました。テーブル内のデータ量は多くなく、読み取りが多く書き込みが少ない状況であるため、単純に 1000 ずつ拡張しました。

質問

MySQL では、自動増分主キーをより大きな値に更新すると (たとえば、自動増分 ID の最大値が 1000 で、ID=49 のレコードを ID=1049 に更新すると)、MySQL はテーブルの自動増分値を更新後の値に変更しません。 DDL や再起動後など、場合によっては、業務がエラーを報告し始めます。 このとき、現在の操作を知らないと、現在の業務操作に問題があると誤解する可能性があります。 実際は、更新 ID によって埋められた落とし穴 (主キーの競合) が原因です。
以下のように表示されます。

図1: 更新前のオリジナルデータ

生データ

更新ステートメントを実行する

テスト セット id = 2 の場合、テスト セット id = 10 を更新します。

図2: 更新されたデータ

更新されたデータ

新しい挿入ステートメントを実行する

テスト(名前)値を挿入('dddd')

図3: 挿入された新しいデータ

新しいデータを挿入した後

この時点で、誰もがこの問題に遭遇したことがあると思います。更新後、最初は問題がないかもしれませんが、自己増加 ID が更新した最大値に追いつくと、ID の競合は避けられません。 。 。

解決方法

1. 個人的なテストライブラリの場合は重要ではありません。データベースを再起動できます。
2. もちろん、あなたが非常にわがままでない限り (そして、わがままを言うのに DBA の同行が必要)、オンライン データベースをこのように設定することはできません。このとき、ソフト削除されたデータなど、ビジネス上意味のないデータを挿入するために ID を指定してみることができます。(私のケース リストにはソフト削除マークがありません。ご理解いただけると思います。)

テスト(id,name)値(20,'eeee')を挿入します。

操作後は図のようになります。

IDを指定して挿入

次のSQL文を実行して結果を比較します。

テスト(名前)値('ffff')を挿入します。

比較結果

この時点で、自動インクリメント ID は最大値から増加し始めています。

情報を検索したところ、このバグは 2005 年に発生したが、パフォーマンスとシナリオが少ないために修正されなかったことがわかりました。この問題は、MySQL 8.0.11 では正常に動作します。

これで、Mysql の自動増分主キー ID の更新で発生した問題に関するこの記事は終了です。Mysql の自動増分主キー ID の更新に関する関連コンテンツの詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL 主キー ID を生成する方法 (自己増分、一意、不規則)
  • MySQLの自動増分主キーIDはこのように処理されません

<<:  HTML テーブル_Powernode Java アカデミー

>>:  指定されたIEブラウザのレンダリング方法の詳細な理解

推薦する

IIS を使用して X-Forwarded-For ヘッダー (XFF) を呼び出して訪問者の実際の IP を記録する 2 つの方法

問題: IIS を通じて公開された Web サイトは F5 デバイスの背後に配置されています。透過的...

Reactはグローバル箇条書きボックスメソッドをカプセル化します

この記事の例では、Reactカプセル化グローバルポップアップボックスの具体的なコードを参考までに共有...

MySQL 5.0.96 for Windows x86 32 ビット グリーン簡易版インストール チュートリアル

MySQL 5.0 は、いくつかの「高度な機能」があるため定番となっています。これは、Windows...

MySQLデータベースのパスワードを忘れた場合の解決策

先ほど MySQL パスワードを設定したのに、外食したり荷物を受け取ったりするときにパスワードを忘れ...

Docker クリーンアップ環境操作

丁寧に掃除を始めましょう!未使用ボリュームの一覧docker ボリューム ls -qf dangli...

MySQL と Golan 間の従来の分散トランザクションのための 7 つのソリューション

目次1. 基本理論1.1 取引1.2 分散トランザクション2. 分散トランザクションソリューション2...

Linux7で仮想ホストを実装する3つの方法

1. 同じIPアドレス、異なるポート番号仮想ホスト 1: ホスト IP アドレスは 172.16.3...

ファイルが存在するかどうかを判断する JavaScript サンプルコード

1. ビジネスシナリオ最近はファイルのアップロードやダウンロードに関する開発をしています。ダウンロー...

CSS でコンテンツが長すぎる問題を解決する方法の詳細な説明

CSS を記述するときに、デザインに存在する重要なケースを忘れてしまうことがあります。たとえば、コン...

Vueはファイルのアップロードとダウンロードを実装します

この記事では、参考までにVueのファイルのアップロードとダウンロードの具体的なコードを紹介します。具...

ボタンをクリックした後のCSS読み込み効果を実現する

自社製品にクリック後1~2秒待機時間があるボタン(確認メールを送信する)があるため、クリック後の1~...

WeChatミニプログラムページで値を返す4つの解決策のまとめ

目次使用シナリオ解決1. globalDataを使用して実装する2. ローカルキャッシュストレージを...

MySQL テーブル フィールドの時間設定のデフォルト値

アプリケーションシナリオデータ テーブルでは、アプリケーションは各データがいつ作成されたかを記録する...

Nginx コンパイル済み nginx - 新しいモジュールを追加

1. 既存のモジュールを表示する nginx の sbin ディレクトリに nginx の sbin...

MySQL 5.6 の「暗黙的な変換」によりインデックスが失敗し、データが不正確になる

背景SQL クエリを実行するときに、where 条件の vachar 型フィールドの単一引用符を削除...