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


MySQL 中的“unsigned”是一種資料型別。每當我們將 unsigned 應用於任何列時,這意味著您不能插入負數。例如,對於非常大的數字,您可以使用 unsigned 型別。

使用 unsigned int 的最大範圍是 4294967295。

Note: If you insert negative value you will get a MySQL error.

以下是 unsigned 型別的示例演示。讓我們首先建立一個包含“unsigned”列的表。以下是建立表的查詢:

mysql> create table UnsignedDemoWithPositiveValue
   -> (
   -> Distance int unsigned
   -> );
Query OK, 0 rows affected (0.86 sec)

如果您嘗試插入超過 unsigned 範圍的值 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)

更新於: 2019年7月30日

12K+ 瀏覽量

開啟你的 職業生涯

透過完成課程獲得認證

開始學習
廣告

© . All rights reserved.