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

 更新时间:2026年02月12日 10:11:16   作者:猿java  
在MySQL中,我们定义int类型时需要设置长度,比如INT(10),那么10到底代表什么,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧

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

1. 含义

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

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

2.ZEROFILL的应用

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

CREATE TABLE users (
  id INT(10) ZEROFILL,
  name VARCHAR(50)
);

插入数据:

INSERT INTO users (id, name) VALUES (123, 'Alice');

查询结果:

+-----------+-------+
| id        | name  |
+-----------+-------+
| 0000000123 | Alice |
+-----------+-------+

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

3.MySQL 8.0.17 及以后的变化

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

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

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

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

创建表并插入数据:

CREATE TABLE example (
    id INT(10) NOT NULL,
    name VARCHAR(50)
);

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

查询显示:

SELECT * FROM example;

结果:

+-------+-------+
| id    | name  |
+-------+-------+
|     1 | John  |
| 123456 | Jane  |
+-------+-------+

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

使用 ZEROFILL 的情况:

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;

结果:

+-----------+-------+
| id        | name  |
+-----------+-------+
| 0000000001 | John  |
| 0000123456 | Jane  |
+-----------+-------+

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

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

5. 总结

  • INT(10) 中的 10 代表的是显示宽度,它用于在与 ZEROFILL 一起使用时补充前导零。
  • 不影响数值的存储大小或取值范围。
  • 在 MySQL 8.0.17 及以后版本中,整数类型的显示宽度被废弃,建议不再使用这种方式指定宽度,除非有特定需求。

到此这篇关于MySQL中int(10) 的 10代表什么的文章就介绍到这了,更多相关MySQL int(10) 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL清理binlog日志文件命令详解

    MySQL清理binlog日志文件命令详解

    这篇文章主要介绍了MySQL清理binlog日志文件命令方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • mysql中coalesce()的使用技巧小结

    mysql中coalesce()的使用技巧小结

    在mysql中,其实有不少方法和函数是很有用的,这次介绍一个叫coalesce的,拼写十分麻烦,但其实作用是将返回传入的参数中第一个非null的值,下面这篇文章主要给大家介绍了在mysql中coalesce()使用技巧的相关资料,需要的朋友可以参考下。
    2017-06-06
  • mysql explain的用法(使用explain优化查询语句)

    mysql explain的用法(使用explain优化查询语句)

    mysql explain可以帮助你检查索引和更好的优化查询语句,今天特地学习了下mysql explain的用法,需要的朋友可以参考下
    2017-01-01
  • MySQL多个表的关联字段实现同步更新的解决方案

    MySQL多个表的关联字段实现同步更新的解决方案

    在对数据库表结构进行设计时,为了提高查询效率,会进行一些反规范化设计,如:设计一些冗余字段,但这样可能会存在数据同步问题,故本文给大家介绍了MySQL多个表的关联字段实现同步更新的解决方案,需要的朋友可以参考下
    2024-11-11
  • MySQL replace函数替换字符串语句的用法

    MySQL replace函数替换字符串语句的用法

    MySQL replace函数我们经常用到,下面就为您详细介绍MySQL replace函数的用法,希望对您学习MySQL replace函数方面能有所启迪。
    2010-12-12
  • 深入理解MySQL中MVCC与BufferPool缓存机制

    深入理解MySQL中MVCC与BufferPool缓存机制

    这篇文章主要介绍了深入理解MySQL中MVCC与BufferPool缓存机制,MySQL默认RR隔离级别就是通过该机制来保证的MVCC,更多主题相关内容,需要的可以参考下面文章内容介绍
    2022-05-05
  • MySQL数据库Event定时执行任务详解

    MySQL数据库Event定时执行任务详解

    这篇文章主要介绍了MySQL数据库Event定时执行任务
    2017-12-12
  • 基于mysql实现group by取各分组最新一条数据

    基于mysql实现group by取各分组最新一条数据

    这篇文章主要介绍了基于mysql实现group by取各分组最新一条数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • MySQL优化之连接优化

    MySQL优化之连接优化

    MySQL连接优化主要指客户端连接数据库以及数据库为响应客户端的请求而打开数据表和索引的过程中涉及到的参数调整。下面我们来详细的探讨下
    2017-03-03
  • mysql拆分字符串作为查询条件的示例代码

    mysql拆分字符串作为查询条件的示例代码

    本文主要介绍了mysql拆分字符串作为查询条件的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07

最新评论