これは私が知っている問題ですが、私は罠に陥りそうになりました(忘れそうになりましたが、幸いにもオンライン前にオンラインポイントを整理したときに思い出しました)ので、ここに特別に記録しました 自動インクリメント 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. 個人的なテストライブラリの場合は重要ではありません。データベースを再起動できます。 テスト(id,name)値(20,'eeee')を挿入します。 操作後は図のようになります。 次のSQL文を実行して結果を比較します。 テスト(名前)値('ffff')を挿入します。 この時点で、自動インクリメント ID は最大値から増加し始めています。 情報を検索したところ、このバグは 2005 年に発生したが、パフォーマンスとシナリオが少ないために修正されなかったことがわかりました。この問題は、MySQL 8.0.11 では正常に動作します。 これで、Mysql の自動増分主キー ID の更新で発生した問題に関するこの記事は終了です。Mysql の自動増分主キー ID の更新に関する関連コンテンツの詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: HTML テーブル_Powernode Java アカデミー
>>: 指定されたIEブラウザのレンダリング方法の詳細な理解
同僚から、一時テーブルを使用して変数データを挿入して表示する方法を教わったことがありますが、この方法...
先日、rsync を使用して LAN 上の別のシステムに大きなファイルを転送していました。非常に大き...
目次序文🍹準備🍲vue3 の使い方🍖 実装要約する序文最近、私の最初の公式 vue3 + ts プロ...
2008年5月12日に四川省汶川市で発生した地震により、多くの命が失われ、遺憾なことと存じます。国務...
序文Reduce() メソッドは関数を累積器として受け取り、配列内の各値 (左から右へ) が単一の値...
目次環境まとめモジュール機能関連文書ソースコード分析CCGame.js CCInputManager...
CentOS 8 がリリースされてから随分経ちました。Linux 仮想マシンをいじっている人間として...
目次継承ES5 プロトタイプ継承ES6 クラス継承両者の違いES5プロトタイプ継承の内部実装ES6 ...
序文「大規模なフロントエンド プロジェクト向け」に設計されたフロントエンド フレームワークである A...
最近の問題としては、次のような現象があります。システムには、docker run コマンドを継続的に...
需要背景チームには統合テストが必要であり、そのためには、mysql や rabbitmq などのミド...
序文WeChat ミニプログラム プロジェクトでユーザー情報を取得し、ユーザー ログインを実装する場...
この記事の例では、日付と時刻の選択を実装するための uniapp の具体的なコードを参考までに共有し...
目次背景複合インデックスを理解する左端一致原則フィールド順序の影響複合インデックスは単一のインデック...
背景tomcat によって生成された catalina.out ログ ファイルが分割されていない場合...