MySQL 中的“unsigned”是什么意思以及何时使用它?

2023年 9月 17日 69.4k 0

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”是什么意思以及何时使用它?的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论