MySQL 中的"unsigned"是什么意思,什么时候用?
mysqlmysqli database
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)
如果您尝试插入无符号的 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)