首頁  >  文章  >  資料庫  >  MySQL 中的「unsigned」是什麼意思以及何時使用它?

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

王林
王林轉載
2023-09-17 15:29:021526瀏覽

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 中的「unsigned」是什麼意思以及何時使用它?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:tutorialspoint.com。如有侵權,請聯絡admin@php.cn刪除