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分表自动化创建的实现方案

    MySQL分表自动化创建的实现方案

    在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在多个表中,从而提高数据库的性能和可维护性,本文介绍了MySQL分表自动化创建的实现方案
    2025-01-01
  • Ubuntu20下MySQL 8.0.28 安装卸载方法图文教程

    Ubuntu20下MySQL 8.0.28 安装卸载方法图文教程

    这篇文章主要为大家详细介绍了Ubuntu20下MySQL 8.0.28 安装卸载方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • Mysql使用kill命令解决死锁问题

    Mysql使用kill命令解决死锁问题

    这篇文章主要介绍了Mysql使用kill命令解决死锁问题的相关资料,需要的朋友可以参考下
    2017-06-06
  • sql 流水号获取代码实例

    sql 流水号获取代码实例

    这篇文章主要介绍了sql 流水号获取代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • Mysql架构图解读

    Mysql架构图解读

    这篇文章主要介绍了Mysql架构图,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • MySQL判断列的值既不为NULL又不为空字符串的问题

    MySQL判断列的值既不为NULL又不为空字符串的问题

    这篇文章主要介绍了MySQL判断列的值既不为NULL又不为空字符串的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • MySql5.x升级MySql8.x的方法步骤

    MySql5.x升级MySql8.x的方法步骤

    这篇文章主要介绍了MySql5.x升级MySql8.x的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • 关于MySQL的体系结构及存储引擎图解

    关于MySQL的体系结构及存储引擎图解

    这篇文章主要介绍了关于MySQL的体系结构及存储引擎图解,MySQL整体的逻辑结构可以分为4层,客户层、服务层、存储引擎层、数据层,需要的朋友可以参考下
    2023-05-05
  • 浅析MySQL并行复制

    浅析MySQL并行复制

    这篇文章主要介绍了MySQL并行复制的相关资料,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-11-11
  • MySQL慢查询分析工具pt-query-digest详解

    MySQL慢查询分析工具pt-query-digest详解

    pt-query-digest是用于分析mysql慢查询的一个工具,它可以分析binlog、General log、slowlog,也可以通过SHOWPROCESSLIST或者通过tcpdump抓取的MySQL协议数据来进行分析,这篇文章主要介绍了MySQL慢查询分析工具pt-query-digest详解,需要的朋友可以参考下
    2023-01-01

最新评论