導入: MySQL を使用してテーブルを作成する場合、通常は自動インクリメント フィールド (AUTO_INCREMENT) を作成し、このフィールドを主キーとして使用します。この記事では、自動増分 ID に関するすべてを質問と回答の形式で説明します。 注:この記事はすべて Innodb ストレージ エンジンに基づいています。 あまり長々と話さずに、詳しい紹介を一緒に見ていきましょう。 1. MySQL ではなぜ自動インクリメント列 ID を主キーとして設定することを推奨しているのですか?
要約すると、自動インクリメント列を主キーとして使用すると、アクセス効率が最高になります。 2. 自動インクリメント列 ID は必ず連続している必要がありますか? 自動増分 ID の増分は必ずしも連続的ではありません。 まず、MySQL の自動インクリメント値の保存戦略を見てみましょう。
自動増分 ID が不連続になる原因となる状況としては、次のようなものが考えられます。 1. ユニークキーの競合 2. トランザクションのロールバック 3. 自動増分 ID を一括適用する SELECT ステートメントを挿入します。 3.自動増分IDに上限はありますか? 自動インクリメント ID は整数フィールドです。成長 ID を定義するために int 型を使用することが多いのですが、int 型には上限があるため、成長 ID にも上限があります。
上記の表から、自動インクリメントフィールドが int signed 型を使用する場合、最大値は 2147483647 に達し、21 億を超え、int unsigned 型を使用する場合、最大値は 4294967295 に達し、42 億を超えることがわかります。もちろん、bigint はより広い範囲を表すことができます。 次に、自動インクリメント ID が最大値に達し、データを再度挿入すると何が起こるかをテストします。 テーブル t(id int unsigned auto_increment primary key) を作成します。auto_increment=4294967295; t 値に挿入します(null); // 4294967295 行を正常に挿入しました テーブル t の作成を表示します。 /* テーブル `t` を作成する ( `id` int(10) 符号なし NOT NULL AUTO_INCREMENT, 主キー (`id`) )ENGINE=InnoDB AUTO_INCREMENT=4294967295; */ t 値に挿入します(null); //キー 'PRIMARY' の重複エントリ '4294967295' 実験から、自動インクリメント ID が最大値に達すると、拡張できないことがわかります。最初の挿入ステートメントでデータが正常に挿入された後、このテーブルの AUTO_INCREMENT は変更されず (4294967295 のまま)、2 番目の挿入ステートメントで同じ自動インクリメント ID 値が取得されます。挿入ステートメントを再度実行しようとすると、主キーの競合エラーが報告されます。 4. 自動インクリメント列をどのように維持すればよいですか? メンテナンスに関しては、次の 2 つの提案が提供されています。 1. フィールド タイプの選択: int unsigned タイプの使用をお勧めします。テーブル内のデータ量が非常に大きくなることが予想される場合は、代わりに bigint unsigned タイプを使用できます。 2. 主キーのオーバーフローを防ぐために、大きなテーブルの自動インクリメント値にさらに注意を払います。 要約する 以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。 以下もご興味があるかもしれません:
|
>>: Nginx 1つのドメイン名で複数のプロジェクトにアクセスする方法の例
Webkit スクロールバー スタイルのリセット1. スクロールバーには、スクロールバー ボタンとト...
この記事の例では、双方向データバインディングを実現するためのjsの具体的なコードを参考までに共有して...
1. リポジトリイメージをダウンロードする docker プルレジストリ 2. プライベートウェアハ...
この記事では、HTTP プロトコルのリファラーのメタデータ パラメータの提案について説明します。この...
目次アプリを登録するときに何をすればよいですか?ページを登録するときに通常何をする必要がありますか?...
MySQL の機能: MySQL は、スウェーデンの会社 MySQL AB によって開発されたリレー...
私たちは Web 開発者として、プロの DBA ではありませんが、データベースなしではやっていけませ...
目次序文文章1. 終了1.1 クロージャとは何ですか? 1.2 クロージャの特性1.3 クロージャを...
1. オーバーフローOverflow はオーバーフロー(コンテナ)です。コンテンツがコンテナを越える...
目次1. はじめに2. 関数型プログラミングとは何ですか? 3. 純粋関数(関数型プログラミングの基...
1. インデックスはnull値を保存しないより正確に言うと、単一列インデックスには null 値は格...
今日、Alibaba Cloudからディスク警告通知を受け取りました。確認したところ、100Gのスペ...
MySQL 全文検索中国語ソリューション最近、会社のプロジェクトで、データベースで中国語を検索する機...
MySQL サーバーをシャットダウンする場合、シャットダウン方法に応じてさまざまな問題が発生する可能...
この記事では、gearman+mysql メソッドを使用して永続化操作を実装します。ご参考までに、詳...