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”是什么意思以及何時使用它?的詳細內容,更多請關注www.92cms.cn其它相關文章!