资深开发居然还分不清 int(1)、int(20) 的区别

前言

  • 最近我和一个同事共同完成一个功能,我们对原表新增了订单ID字段,我使用了下面的 SQL 语句:alter table xxx ADD order_id int(1),然后同事对我说,int(1) 这么小怎么够用?然后我一通解释说服了队友,他连说"原来如此",成功装逼。
  • 其实我不是第一次遇到有朋友问这个问题,今天我们就一起来看看 int(1)、int(20) 到底有什么区别?

数据准备

  • 创建测试表 test_table,包含两个测试字段area int(1)、area_1 int(20):
sql 复制代码
CREATE TABLE `test_table` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `area` int(1) unsigned DEFAULT NULL,
  `area_1` int(20) unsigned DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

int(1)、int(20) 存储大小有区别?

  • 我们知道在 MySQL 中 int 类型占4个字节,对于无符号整形最大值为:2^32-1 = 4294967295,下面我们看看int(1)、int(20)可以存储 int 类型最大值?
sql 复制代码
INSERT INTO `test_table` (`area`, `area_1`) VALUES (4294967295, 4294967295)
> Affected rows: 1
> 查询时间: 0.002s
  • 可以看到,int(1)、int(20) 都可以存储 int 类型最大值,说明对存储大小无影响。那么我们的1和20用什么作用呢?答案就是对齐填充,当联合零填充(zerofill) 使用时,我们配置的值才会体现效果。

零填充(zerofill)

  • 所谓零填充就是当我们数字位小于我们指定位数时,使用0填充补全位数,比如指定位数为4位,数为23,那么实际会被填充为 0023。
  • 下面来看一下实际例子:将 area 和 area_1 字段配置为 zerofill。
sql 复制代码
CREATE TABLE `test_table` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `area` int(1) unsigned zerofill DEFAULT NULL,
  `area_1` int(20) unsigned zerofill DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4;
  • 展示效果:
  • 我们可以看到 area_1 不足20位时使用0补齐到20位,area 指定位数为 1 位实际并没有效果,因为数字至少为1位,对 NULL 不生效。
  • 零填充(zerofill)在一些需要数字对齐的场景中可能使用,但实践中并不推荐,对数据库依赖性太强。

总结

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

个人简介

👋 你好,我是 Lorin 洛林,一位 Java 后端技术开发者!座右铭:Technology has the power to make the world a better place.

🚀 我对技术的热情是我不断学习和分享的动力。我的博客是一个关于Java生态系统、后端开发和最新技术趋势的地方。

🧠 作为一个 Java 后端技术爱好者,我不仅热衷于探索语言的新特性和技术的深度,还热衷于分享我的见解和最佳实践。我相信知识的分享和社区合作可以帮助我们共同成长。

💡 在我的博客上,你将找到关于Java核心概念、JVM 底层技术、常用框架如Spring和Mybatis 、MySQL等数据库管理、RabbitMQ、Rocketmq等消息中间件、性能优化等内容的深入文章。我也将分享一些编程技巧和解决问题的方法,以帮助你更好地掌握Java编程。

🌐 我鼓励互动和建立社区,因此请留下你的问题、建议或主题请求,让我知道你感兴趣的内容。此外,我将分享最新的互联网和技术资讯,以确保你与技术世界的最新发展保持联系。我期待与你一起在技术之路上前进,一起探讨技术世界的无限可能性。

📖 保持关注我的博客,让我们共同追求技术卓越。

相关推荐
好奇的菜鸟3 小时前
Spring Boot 事务失效问题:同一个 Service 类中方法调用导致事务失效的原因及解决方案
数据库·spring boot·sql
岁岁岁平安3 小时前
Redis基础学习(五大值数据类型的常用操作命令)
数据库·redis·学习·redis list·redis hash·redis set·redis string
姑苏洛言5 小时前
编写产品需求文档:黄历日历小程序
前端·javascript·后端
小光学长5 小时前
基于vue框架的防疫科普网站0838x(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
极限实验室5 小时前
使用 Docker Compose 简化 INFINI Console 与 Easysearch 环境搭建
数据库·docker·devops
飞翔的佩奇5 小时前
Java项目:基于SSM框架实现的旅游协会管理系统【ssm+B/S架构+源码+数据库+毕业论文】
java·数据库·mysql·毕业设计·ssm·旅游·jsp
姑苏洛言6 小时前
搭建一款结合传统黄历功能的日历小程序
前端·javascript·后端
你的人类朋友6 小时前
🍃认识一下boomi
后端
苏三说技术6 小时前
MySQL的三大日志
后端
豌豆花下猫6 小时前
让 Python 代码飙升330倍:从入门到精通的四种性能优化实践
后端·python·ai