MySQLの自動増分主キーIDはこのように処理されません

MySQLの自動増分主キーIDはこのように処理されません

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 を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • MySQL の主キーとその自動増分の設定に関するチュートリアル
  • MySQL で自動増分主キーの型を int から char に変更する例
  • MySQL の自動増分 ID (主キー) が不足した場合の解決策
  • MySQL の自動増分主キーが使い果たされた場合の対処方法
  • MySQL 8 の新機能: 自動増分主キーの永続性に関する詳細な説明
  • MySQL の非主キー自己増分使用例の分析
  • MySQLの自動増分主キーの実装の詳細な説明
  • MySQL の自動インクリメント主キーが連続していないのはなぜですか?

<<:  CSSのoutline-offsetプロパティを使用してプラス記号を実装する

>>:  docker compose デプロイメントにおけるマスタースレーブレプリケーションの実装

推薦する

包括的なウェブサイト評価ソリューション

<br />「XXXのウェブサイトを見てみませんか?」といった質問をされることもあります...

antd ツリーと親子コンポーネント間の値転送問題について (React のまとめ)

プロジェクト要件: 製品ツリー ノードをクリックすると、そのノードのすべての親ノードが取得され、表に...

Ubuntu 20.04 LTSの詳細なインストール履歴

この記事では、USB ブート ディスクの作成とシステムのインストールについて説明します。システム構成...

ウェブページ HTML 特殊記号 HTML 特殊文字比較表

特殊記号名前付きエンティティ10進数エンコード特殊記号名前付きエンティティ10進数エンコードアルファ...

Linux でのソース パッケージ インストールのサービス管理

目次1. ソースパッケージサービスの起動管理2. ソースパッケージサービスのセルフスタート管理3. ...

キャンバス操作プラグイン fabric.js の使い方を詳しく解説

Fabric.js は非常に便利なキャンバス操作プラグインです。ここでは、日常のプロジェクトで使用さ...

Vue のデータ応答性に関する詳細な理解

目次1. ES 構文のゲッターとセッター2. ES構文でのdefineProperty 3. Vue...

カスタム変数を使用した MySQL クエリの最適化

目次並べ替えクエリの最適化変更されたばかりのデータ行を繰り返し取得しないようにする遅延ロードされた結...

HTML 左、中央、右の適応レイアウト (calc css 式を使用)

最新の HTML 標準には、レイアウトを計算するために使用できる calc CSS 式があります。し...

現在のブラウザが JavaScript でヘッドレス ブラウザであるかどうかを検出する方法

目次ヘッドレスブラウザとは何ですか?なぜ「ヘッドレス」ブラウザと呼ばれるのでしょうか?ヘッドレスブラ...

純粋な CSS で「テキストオーバーフローの切り捨てと省略」を実装するいくつかの方法

私たちの日常的な開発作業では、テキストのオーバーフロー、切り捨て、省略は、考慮する必要がある非常に一...

この記事では、CSSのようなJSモジュールをインポートする方法を説明します。

目次序文構築可能なスタイルシートとは何ですか? CSSモジュールスクリプトの使用インポートアサーショ...

Windows 10 で MySql の解凍バージョンをインストールして構成する方法のチュートリアル

Windows 10 で MySql データベースの解凍バージョンをインストールするステップ 1: ...

MySQL外部キーの基本的な機能と使用方法の詳細な説明

この記事では、例を使用して、MySQL 外部キーの基本的な機能と使用方法を説明します。ご参考までに、...

mysqlは内部コマンドエラーの解決策ではありません

「mysqlは内部コマンドではありません」というエラーは、mysqlのbinディレクトリパスが環境変...