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+ 浏览量

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告