MySQL中int(1)与int(20)的区别

我们经常会遇到数据类型的问题。其中,int是一种常见的整数类型,但是在实际使用中,我们可能会遇到int(1)和int(20)这样的数据类型。那么,它们之间有什么区别呢?

在MySQL中,int(M)是一个整数类型,总共可以存储的位数是4个字节(32位)。其中,M表示显示宽度,也就是显示的最大长度。如果数值的位数小于M,那么在数字前面会用空格进行填充;如果数值的位数大于M,那么会进行裁剪。

int(1)和int(20)的区别:

int(1): 表示显示宽度为1,用于控制显示时的位数,不限制存储的范围。

int(20): 表示显示宽度为20,同样不限制存储的范围,用于对齐和显示效果。

int(1)和int(20)的主要区别在于显示宽度不同,这会影响到数据的显示效果。但是,它们在存储数值的范围上是一样的,都是-2^31到

2^31-1。在实际使用中,我们应该根据实际需求来选择合适的数据类型。如果需要精确控制数据的显示宽度,那么就可以使用int(M);如果不需要精确控制数据的显示宽度,那么就可以直接使用int(1)或int即可。

测试一:int(1)、int(20) 都可以存储 int 类型最大值,说明对存储大小无影响。

--创建表

复制代码
CREATE TABLE example_table (
    small_int_col INT(1),
    large_int_col INT(20)
);

-- 插入数据

复制代码
INSERT INTO example_table (small_int_col, large_int_col) VALUES (123456789, 123456789);

--查询结果

复制代码
SELECT * FROM example_table

测试二:zerofill(零填充)属性

通过使用ZEROFILL属性来填充零,以保持固定的位数。这对于要求固定位数的应用场景非常有用,例如订单号、账户号等。

--创建表

复制代码
CREATE TABLE example_table_zerofill (
    small_int_col INT(1) ZEROFILL,
    large_int_col INT(20) ZEROFILL
);

-- 插入数据

复制代码
INSERT INTO example_table_zerofill (small_int_col, large_int_col) VALUES (123456789, 12345), (123456789, 23456);

--查询结果

复制代码
SELECT * FROM example_table_zerofill
相关推荐
m0_613856299 分钟前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios79419 分钟前
VPR:Pitts50K和Norland数据集下载
数据库
东风破13723 分钟前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
收获不止数据库32 分钟前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
小宇的天下1 小时前
Virtuoso GUI 界面中的关键模块定义
数据库
bqq198610261 小时前
MySQL 5.7 与 MySQL 8.0 的主要区别
数据库·mysql
Elastic 中国社区官方博客2 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索
互联网推荐官2 小时前
上海软件定制开发全流程拆解:需求分析、技术选型与交付管理的工程实践
大数据·数据库·需求分析
专注API从业者2 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
大迪deblog2 小时前
系统架构师-数据库-数据库设计
数据库·oracle·系统架构