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)登录后复制
插入超出范围的值。
mysql> insert into UnsignedDemoWithPositiveValue values(4294967296); ERROR 1264 (22003): Out of range value for column 'Distance' at row 1登录后复制
现在我将另一个值 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登录后复制
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)登录后复制