int(1) の長さ 1 は、許可されたストレージ幅を表していないことはすでにご存知かもしれません。 しかし、この長さが何を意味するのかを実際に研究した人は多くありません。今日は簡単に分析してみたいと思います。 テーブル作成の簡単な例を見てみましょう。 テーブルテストを作成( id int(11) 符号なし NOT NULL AUTO_INCREMENT, uid int(3) NULLではない、 主キー (id) )ENGINE=InnoDB デフォルト文字セット=utf8mb4; ここではuidフィールドを例として取り上げ、int(3)に設定します。 質問は、int(3) を設定すると、データ 1234 を保存できないかどうかです。 次に、次のSQL文を入力してテストします。 `test` (`uid`) に VALUES(1234) を挿入します。 `test` (`uid`) に VALUES(12345678) を挿入します。 結果のグラフは次のようになります。 友人は、上記のSQL文を通じてデータ1234が正常に挿入されたことを確認できます。さらに、より多くの桁のデータを挿入することもできます。これはなぜでしょうか?以下を参照してください。 理由は次のとおりです。 この int(n) は次のように簡単に理解できます。 この長さは、このフィールドに格納されているデータの幅が n 桁であることを MySQL に伝えるためのものです。もちろん、n 桁を格納しない場合でも、(この型の格納範囲内であれば) MySQL は普通に格納することもできます。 次に、test2テーブルを再度作成し、今度はuidフィールドに次の制約を追加します: unsignedおよびzerofill ==フィールド制約については後で詳しく説明します== MySQL コードは次のとおりです。 テーブルtest2を作成します( id int(11) 符号なし NOT NULL AUTO_INCREMENT, uid int(3) 符号なしゼロフィル NOT NULL、 主キー (id) )ENGINE=InnoDB デフォルト文字セット=utf8mb4; これで、私の uid フィールド: 長さ (n) = 3、フィールド制約 = 符号なし、ゼロフィル: (符号なし制約、数字制約を埋めるために 0 を使用) この制約フィールドを設定すると、テーブルにデータを挿入するときに、uid フィールドが 3 桁未満の場合、システムは自動的に左側に 0 を入力します。 uid フィールドに数字 33 を挿入してコードをテストできます。 `test2` (`uid`) VALUES(33) に挿入します。 結果のグラフは次のようになります。 長さが3未満の場合は、左から0で埋められることに驚きましたか?ハハハハ つまり、int の後の長さ n は、格納する数値のサイズとは何の関係もないことが明確にわかるはずです。 ==要約:== テーブル フィールドのデータ型を int として定義する場合、その後ろの長さ n は意味がありません。この型の保存範囲内であれば、MySQL は正常に保存できます。左側に 0 を埋め込む必要がある場合は、このフィールドにゼロ埋め制約と unsigned 制約が必要です。 MySQL の int(n) の後の n の意味についてのこの記事はこれで終わりです。MySQL int(n) に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: JavaScript はパスワードボックスの入力検証を実装します
>>: docker-compose が遅すぎる場合の解決策の詳細な説明
HTML デザインパターン学習ノート今週は主にHTMLデザインパターンを学びました。学習内容をまとめ...
目次序文仮想リストとは何ですか?デモ効果準備スクリーンの高さとボックスの高さ最適化要約する序文人気の...
MySQL で concat 関数を使用する方法: CONCAT(文字列1、文字列2、…)戻り値は、...
最近、関連テーブル内のすべてのフィールドをクエリし、それらを 1 つのフィールドに再グループ化する必...
NGINX の全体的なアーキテクチャは、連携して動作する一連のプロセスによって特徴付けられます。メイ...
目次依存関係をインストールする構成使用1.アイコン検索ページに入る2. 使用したいアイコンの英語名を...
効果デモ.html <html> <ヘッド> <メタ文字セット=&qu...
Vue プラグインがエラーを報告しました: このページで Vue.js が検出されましたVueプラグ...
公式サイトからMySQL-5.7.11-winx64の圧縮版をダウンロード。インストール後、パスワー...
序文要件を満たす特定のデータをデータベースから取得する必要があります。Select ABC FROM...
まず問題の説明から始めましょう:同じページで、1 つのタブに float:left が必要で、もう ...
ファイアウォールファイアウォールは一連のルールです。パケットが保護されたネットワーク空間に出入りする...
この記事では、JavaScriptで画像のプリロードと遅延ロードを実装するための具体的なコードを参考...
実験環境: MYSQL 5.7.22バイナリログを有効にするログ形式 MIXED実験プロセス: 1....
Redisの本やSpring Cloud Alibabaの本を執筆した際に、一部の分散コンポーネント...