MySQL中,int(10) 的 10代表什么?

你好,我是猿java

在 MySQL 中,我们定义int类型时需要设置长度,比如INT(10),那么10 到底代表什么?如果超过这个范围会出现什么问题?这篇文章我们来详细地聊一聊。

1. 含义

在数据类型如 INT 后面的括号中的数字(例如 INT(10))指定了显示宽度 ,即当使用 ZEROFILL 属性时,系统会在数值前补零以达到指定的宽度。

  • 存储空间INT 数据类型总是占用 4 字节(32 位),无论显示宽度是多少。
  • 取值范围 :对于有符号的 INT,范围是 -21474836482147483647;对于无符号的 INT UNSIGNED,范围是 04294967295。显示宽度不会改变这一范围。

2. ZEROFILL 的应用

当在 INT 类型后使用 ZEROFILL 时,MySQL 会在数值前补零,以符合指定的显示宽度。如下示例:

sql 复制代码
CREATE TABLE users (
  id INT(10) ZEROFILL,
  name VARCHAR(50)
);

插入数据:

sql 复制代码
INSERT INTO users (id, name) VALUES (123, 'Alice');

查询结果:

diff 复制代码
+-----------+-------+
| id        | name  |
+-----------+-------+
| 0000000123 | Alice |
+-----------+-------+

在这个例子中,id 字段显示为 0000000123,达到 10 位宽度。

3. MySQL 8.0.17 及以后的变化

MySQL 8.0.17 版本开始,整数类型的显示宽度被废弃(deprecated),即使指定了显示宽度,默认情况下也不再影响存储或显示。这意味着:

  • 影响 :不再推荐在整数类型后指定显示宽度,如 INT(10) 中的 10 将被忽略,除非配合 ZEROFILL 使用。

  • 推荐做法 :直接使用 INT 而无需指定显示宽度,除非确实需要与现有系统兼容或有特殊需求。

为了更好地理解INT,下面通过几个例子详细解释。

创建表并插入数据:

sql 复制代码
CREATE TABLE example (
    id INT(10) NOT NULL,
    name VARCHAR(50)
);

INSERT INTO example (id, name) VALUES (1, 'John'), (123456, 'Jane');

查询显示:

sql 复制代码
SELECT * FROM example;

结果:

diff 复制代码
+-------+-------+
| id    | name  |
+-------+-------+
|     1 | John  |
| 123456 | Jane  |
+-------+-------+

在没有使用 ZEROFILL 的情况下,显示宽度 10 并未影响输出格式。

使用 ZEROFILL 的情况:

sql 复制代码
CREATE TABLE example_zf (
    id INT(10) ZEROFILL NOT NULL,
    name VARCHAR(50)
);

INSERT INTO example_zf (id, name) VALUES (1, 'John'), (123456, 'Jane');

SELECT * FROM example_zf;

结果:

diff 复制代码
+-----------+-------+
| id        | name  |
+-----------+-------+
| 0000000001 | John  |
| 0000123456 | Jane  |
+-----------+-------+

这里,id 字段根据显示宽度 10 补充了前导零。

注意:由于 MySQL 8.0.17 及以后的版本中显示宽度被废弃,建议在设计数据库时避免依赖显示宽度,除非有明确的需求和兼容性考虑。

5. 总结

  • INT(10) 中的 10 代表的是显示宽度 ,它用于在与 ZEROFILL 一起使用时补充前导零。

  • 不影响数值的存储大小或取值范围。

  • 在 MySQL 8.0.17 及以后版本中,整数类型的显示宽度被废弃,建议不再使用这种方式指定宽度,除非有特定需求。

6. 学习交流

如果你觉得文章有帮助,请帮忙转发给更多的好友,或关注公众号:猿java,持续输出硬核文章。

相关推荐
Orange30151117 分钟前
ES6~ES11新特性全解析
java·前端·javascript·es6
桂月二二27 分钟前
Spring Boot 与 Kafka 实现高效消息队列通信的最佳实践
spring boot·后端·kafka
程序员林北北1 小时前
【Golang学习之旅】gRPC 与 REST API 的对比及应用
java·开发语言·后端·学习·云原生·golang
WinsonWu2 小时前
deepseek本地部署(在线、离线)、知识库搭建(个人、组织)与代码接入
人工智能·后端·deepseek
一川晚照人闲立2 小时前
JEECGBOOT前端VUE3版本浏览器兼容支持chrome>=76版本方法
java·前端·vue.js·chrome·anti-design-vue·jeecgboot·jeecg
0wioiw02 小时前
Python基础(SQLAlchemy)
java·开发语言·数据库
Luo_LA2 小时前
【Java 面试 八股文】Redis篇
java·redis·面试
ChinaRainbowSea2 小时前
十四. Redis 新功能
java·数据库·redis·缓存·bootstrap
小胖子——鑫3 小时前
对“云原生”的初印象
java·开发语言·云原生
归宿乐瑶3 小时前
六.logback记录日志文件并按大小日期分割文件
java·spring boot·logback