MySQL における「署名なし」とは何を意味しますか?また、それをいつ使用する必要がありますか?

王林
リリース: 2023-09-17 15:29:02
転載
1613 人が閲覧しました

MySQL 中的“unsigned”是什么意思以及何时使用它?

MySQL の「Unsigned」はデータ型です。符号なしの数値を列に書き込むときは、負の数値を挿入できないことを意味します。非常に大きな数値の場合、符号なし型を使用できるとします。

unsigned int の最大範囲は 4294967295 です。

Note: If you insert negative value you will get a MySQL error.
ログイン後にコピー

これは、符号なし型のデモンストレーションの例です。まず、「符号なし」列を含むテーブルを作成しましょう。以下はテーブルを作成するクエリです -

mysql> create table UnsignedDemoWithPositiveValue
   -> (
   -> Distance int unsigned
   -> );
Query OK, 0 rows affected (0.86 sec)
ログイン後にコピー

符号なしの上限値 4294967295 を挿入しようとすると、値が範囲外であるためエラーが生成されます。

範囲外の値を挿入します。

mysql> insert into UnsignedDemoWithPositiveValue values(4294967296);
ERROR 1264 (22003): Out of range value for column 'Distance' at row 1
ログイン後にコピー

上記の例では、範囲外の 4294967296 を挿入したため、エラーが発生します。

ここで、別の値 4294967295 をテーブルに挿入します。

mysql> insert into UnsignedDemoWithPositiveValue values(4294967295);
Query OK, 1 row affected (0.30 sec)
ログイン後にコピー

上記では、クエリが正常に実行されたことがわかります。

次に、別の例を見てみましょう。負のレコードを挿入すると、次のエラーが表示されます -

mysql> insert into UnsignedDemoWithPositiveValue values(-124);
ERROR 1264 (22003): Out of range value for column 'Distance' at row 1
ログイン後にコピー

今後は、値 124 の正の値のみを挿入します。クエリは次のとおりです -

mysql> insert into UnsignedDemoWithPositiveValue values(124);
Query OK, 1 row affected (0.86 sec)
ログイン後にコピー

上に示すように、クエリは正常に実行されます。

select ステートメントを使用してレコードを表示しましょう。クエリは次のとおりです -

mysql> select *from UnsignedDemoWithPositiveValue;
ログイン後にコピー

これは出力です -

+------------+
| Distance   |
+------------+
| 4294967295 |
| 124        |
+------------+
2 rows in set (0.00 sec)
ログイン後にコピー

以上がMySQL における「署名なし」とは何を意味しますか?また、それをいつ使用する必要がありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:tutorialspoint.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート