MySQLの自動増分主キーIDは段階的に増加しません1. はじめにMySQL データベースにデータを追加し、ON DUPLICATE KEY UPDATE を使用してデータを更新すると、ID が段階的に増加するのではなく、断続的に増加する場合があります。 たとえば、ID が 10 の場合、次に追加されるときには 15 または別の数字になる可能性があります。2 つの数字の間隔は、ON DUPLICATE KEY UPDATE が実行される回数です。つまり、ON DUPLICATE KEY UPDATE は、更新を実行するときにテーブルの主キーを 1 つ増やします。 図に示すように 2. 問題の紹介同じテーブルを追加および変更するときに、2 つのマッパー インターフェイス メソッドを使用しました。つまり、2 つの ON DUPLICATE KEY UPDATE 操作を使用しました。これにより、更新時にテーブルの主キーが増加します。次回挿入時には段階的に増加しません。 3. 解決策データベースの挿入と更新を分割します。 自動増分主キーの利点と欠点主キーの自動増分この方法では、データベースによって提供される自動インクリメント数値フィールドを自動インクリメント主キーとして使用します。その利点は次のとおりです。 (1)データベースは自動的に番号が付けられ、高速かつ段階的に増加し、順序良く保存されるため、検索に非常に便利です。 (2)デジタルタイプは場所を取らず、整理しやすく、プログラムに渡すのに便利です。 (3)システム以外でレコードを追加する場合は、このフィールドを指定する必要はなく、主キーの重複を気にする必要もありません。 実際、その欠点はその利点から生じており、その欠点は次のとおりです。(1)自動増加のため、指定したIDのレコードを手動で挿入するのは面倒です。特に他システムと統合してデータのインポートが必要な場合、元のシステムのIDが主キーと競合しないことを保証するのは困難です(旧システムもデジタルであると仮定)。特に、新しいシステムが起動され、古いシステムと新しいシステムが並行して存在し、データベースが異種であり双方向の同期が必要な場合、自動増分主キーは悪夢になります。 (2)システム統合またはカットオーバー時に、新旧システムの主キーが異なり、数値である場合、主キーのデータ型が変更され、外部キーに関連付けられた他のテーブルも変更され、同様に深刻な結果を招くことになります。 (3)システムもデジタル化されている場合、インポート時に新旧のデータを区別するために、古いデータの主キーの前に文字識別子(「o」、oldなど)を追加して、古いデータであることを示す必要がある場合があります。この場合、自動的に増加するデジタルタイプは別の課題に直面します。 上記は私の個人的な経験です。参考になれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: CSSのoutline-offsetプロパティを使用してプラス記号を実装する
>>: docker compose デプロイメントにおけるマスタースレーブレプリケーションの実装
vueモバイル端末は、画面上で指をスライドさせる方向を判断します。具体的な内容は次のとおりです。これ...
良い画像素材のウェブサイトを見つけるのは難しいです。特に無料です。良い写真には非常に目を引く視覚効果...
以下の内容では、隣接リストを使用してツリー構造を保存する MYSQL のプロセスとソリューションを紹...
コードをコピーコードは次のとおりです。 <前> <div> <sele...
1. DOM要素を挿入、更新、または削除するときに、適切な場合は要素にスタイルクラス名を追加します。...
序文MySQL を学習する際に、MySQL のロック メカニズムについて簡単に理解したことがあると思...
【質問】 HP サーバーを使用しています。SSD が IOPS 約 5000 を書き込むと、%uti...
H5 レイアウトを設計する場合、通常はバナーに遭遇することになります。例えば、2:1 で表示したい場...
今日、MySQL をインストールすると次のエラー メッセージが表示されます。 かなり長い時間ネットで...
開発中に、非常に単純なテキストバブル効果に遭遇しました。これは、おおよそ次のようになります。 うーん...
公式の Docker レジストリを使用して作成されたウェアハウスでは、イメージを削除してもデフォルト...
効果 html <div class="sp-container">...
プロセス アドレス空間の分離は、現代のオペレーティング システムの注目すべき機能です。これは、「古い...
みなさんこんにちは。今日はカルーセルの実装についてお話しします。私が作成したカルーセルの効果は次のと...
Docker コンテナはサービスを提供し、ポート 8888 をリッスンします。外部からアクセスできる...