Mysql中int(1)、int(20)的区别小结

 更新时间:2025年03月04日 10:50:39   作者:李若盛开  
本文主要介绍了Mysql中int(1)、int(20)的区别小结,int后的数字表示最大显示宽度,一般int后面的数字M要配合zerofill一起使用才有效,下面就来具体介绍一下,感兴趣的可以了解一下

在设计数据库表的时候,经常需要设计一个id字段,它的类型一般都是整型int,经常会遇到int(1)、int(20)等。

int的范围:
有符号的整型范围是-2147483648~2147483647
无符号的整型范围是0~4294967295

参看 MySQL 手册,int(M): M indicates the maximum display width for integer types.
int(M)只是用来显示数据的宽度,在 integer 数据类型中,M 表示最大显示宽度,一般int后面的数字M要配合zerofill一起使用才有效。

数据准备

创建测试表 test_table,包含两个测试字段area_1 int(1)、area_2 int(20):

CREATE TABLE `test_table` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `area_1` int(1) unsigned DEFAULT NULL,
  `area_2` int(20) unsigned DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

存储大小

在 MySQL 中 int 类型占4个字节,对于无符号整形最大值为:2^32-1 = 4294967295,下面看看int(1)、int(20)分别可以存储 int 类型最大值?

INSERT INTO `test_table` (`area_1`, `area_2`) VALUES (4294967295, 4294967295)
> Affected rows: 1
> 查询时间: 0.002s

插入成功,int(1)、int(20) 都可以存储 int 类型最大值,说明对存储大小无影响。那么1和20用什么作用呢?答案就是对齐填充,当联合零填充(zerofill) 使用时,配置的值才会体现效果。

零填充(zerofill,一般int后面的数字要配合zerofill一起使用才有效)

所谓零填充就是当数字位小于指定位数时,使用0填充补全位数,比如指定位数为4位,数为23,那么实际会被填充为 0023。

将 area_1 和 area_2 字段配置为 zerofill

CREATE TABLE `test_table` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `area_1` int(1) unsigned <strong>zerofill</strong> DEFAULT NULL,
  `area_2` int(20) unsigned <strong>zerofill</strong> DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4;

可以看到 area_2 不足20位时使用0补齐到20位,area_1 指定位数为 1 位实际并没有效果,因为数字至少为1位,对 NULL 不生效。

零填充(zerofill)在一些需要数字对齐的场景中可能使用,但实践中并不推荐,对数据库依赖性太强。

总结

int后面的数字不能表示字段的长度,int(num)一般加上zerofill,才有效果。

一般整型而言,对于int(1)、int(20) 中指定的位数并不会影响字段的存储大小,而是和零填充(zerofill)联合使用实现对齐填充,实际使用中没有特殊对齐需求,配置为int(1)即可。

注意:零填充只针对于整型,字符串(char、varchar)的“长度”是会受到真正的限制。Char(n)、Varchar(n),括号里的N表示的是该字段可容纳的最大字符数,简单来说就是能存入多少个字符,n的取值范围为:0-255。

到此这篇关于Mysql中int(1)、int(20)的区别小结的文章就介绍到这了,更多相关Mysql int(1) int(20)内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql转PostgreSQL注意事项及说明

    Mysql转PostgreSQL注意事项及说明

    这篇文章主要介绍了Mysql转PostgreSQL注意事项及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-10-10
  • linux使用mysqldump+expect+crontab实现mysql周期冷备份思路详解

    linux使用mysqldump+expect+crontab实现mysql周期冷备份思路详解

    这篇文章主要介绍了linux使用mysqldump+expect+crontab实现mysql周期冷备份,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • MyBatis 动态SQL全面详解

    MyBatis 动态SQL全面详解

    MyBatis 的强大特性之一便是它的动态 SQL。如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦。拼接的时候要确保不能忘了必要的空格,还要注意省掉列名列表最后的逗号。利用动态 SQL 这一特性可以彻底摆脱这种痛苦
    2021-09-09
  • MySQL数据库定时备份的几种实现方法

    MySQL数据库定时备份的几种实现方法

    本文主要介绍了MySQL数据库定时备份的几种实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-07-07
  • Python3.6-MySql中插入文件路径,丢失反斜杠的解决方法

    Python3.6-MySql中插入文件路径,丢失反斜杠的解决方法

    下面小编就为大家带来一篇Python3.6-MySql中插入文件路径,丢失反斜杠的解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • MySQL单表恢复的步骤

    MySQL单表恢复的步骤

    这篇文章主要介绍了MySQL单表恢复的步骤,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-08-08
  • Mysql8报错this is incompatible with sql_mode=only_full_group_by问题

    Mysql8报错this is incompatible with sql_mo

    这篇文章主要介绍了Mysql8报错this is incompatible with sql_mode=only_full_group_by问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • mysql日常锁表之flush_tables详解

    mysql日常锁表之flush_tables详解

    Flushtables和Flushtableswithreadlock是MySQL中的两个命令,用于关闭表对象和清空查询缓存,它们会等待所有正在运行的SQL请求执行结束,如果请求操作的表集合为{tables},则会阻塞其他会话对{tables}表上的所有操作,包括查询和写操作
    2024-11-11
  • MySQL 实现lastInfdexOf的功能案例

    MySQL 实现lastInfdexOf的功能案例

    这篇文章主要介绍了MySQL 实现lastInfdexOf的功能案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • 银河麒麟V10安装MySQL5.7的详细过程

    银河麒麟V10安装MySQL5.7的详细过程

    这篇文章主要介绍了银河麒麟V10安装MySQL5.7,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05

最新评论