服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - 你对MySQL的int(11)真的了解吗?

你对MySQL的int(11)真的了解吗?

2024-01-29 16:58修己xj Mysql

在数据库设计中,INT(3)和INT(11)的区别主要在于它们控制输出时的显示宽度。实际的存储大小是相同的,都占用4个字节。

最近在网上看到一篇关于int(3)和int(11)区别的帖子,我第一反应这不就是它们之间主要涉及存储整型数据时所需的位数,即3位和11位的差异。然而,经过详细阅读文章并进行进一步的资料查询和测试后,我才发现我一直以来对于int(3)的理解存在误差。今天,我打算与家人分享这一新的认识。

你对MySQL的int(11)真的了解吗?mysql-int.jpg

MYSQL int 数据存储范围

首先,需要明确的是,int(3)和int(11)都是表示整数类型,而不是定义整数的存储长度。在MySQL中,INT类型占据4个字节(32位),可以存储范围是-2^31到2^31-1(约-2.1亿到2.1亿),这个范围是固定的,不受括号中数字的影响。

显示宽度

int(3)和int(11) 区别在于显示宽度的影响。当我们定义一个字段为int(3)时,这个数字表示的是在使用ZEROFILL填充字符时的显示宽度,而不是实际存储的整数位数。使用ZEROFILL会在数字不足指定宽度时,在前面用零进行填充。

我们可以在mysql(5.7)中创建数据查看下具体的效果:

创建表:

CREATE TABLE `int_test1` (
  `int_3` int(3) ,
  `int_11` int(11) ,
  `int_zf_3` int(3)  ZEROFILL ,
  `int_zf_11` int(11)  ZEROFILL 
);

添加数据:

INSERT INTO int_test1(int_3,int_11,int_zf_3,int_zf_11) VALUES 
(1,1,1,1),
(2365,2365,2365,2365);

查看数据:

你对MySQL的int(11)真的了解吗?图片

_20240127224156.jpg

可以看到,int() 括号中的数字是在位数不足时如果使用ZEROFILL的话会在前面用零进行填充,补齐到括号中数字的位数。

注意事项

  • 使用ZEROFILL填充字段 时插入负数报错

因为ZEROFILL属性只适用于非负整数。所以当我们插入负数时会报错。

你对MySQL的int(11)真的了解吗?图片

我们打开表的DDl,就可以看到,我们设置ZEROFILL的时候他会自动设置为unsigned(无符号)

你对MySQL的int(11)真的了解吗?图片

  • ZEROFILL只在整数类型上有效,对于其他数据类型(如浮点数)不适用。
  • 在mysql8.0 中,只有设置了ZEROFILL,才能看到int(),否则都是int

实际应用

我们在实际生产环境使用查询的时候通常要把数据库的int数据转化为java对象的Integer,所以ZEROFILL在实际生产中使用的很少,其次我们需要给数据补齐位数的时候通常是在程序中做处理,不会依赖数据库,这样我们的业务才能更灵活。

总结

在数据库设计中,INT(3)和INT(11)的区别主要在于它们控制输出时的显示宽度。实际的存储大小是相同的,都占用4个字节。而括号中的数字在非ZEROFILL的情况下,只是指定了输出时的最小宽度,不足时会用空格填充。在ZEROFILL的情况下,还会影响零填充的总宽度。因此,在选择使用INT(3)还是INT(11)时,主要考虑的是对数据的显示控制需求。

原文地址:https://mp.weixin.qq.com/s/i4qrQK3xn-Axyi3CZAM_lQ

延伸 · 阅读

精彩推荐
  • Mysqlmysql命令行脚本执行操作示例

    mysql命令行脚本执行操作示例

    这篇文章主要介绍了mysql命令行脚本执行操作,结合实例形式分析了MySQL命令行操作相关的登入登出、创建删除、增删改查等操作技巧,需要的朋友可以参考下...

    小飞侠v科比2172020-12-17
  • MysqlMySQL关于exists的一个bug

    MySQL关于exists的一个bug

    今天小编给大家分享一个mysql关于exists的一个bug问题,非常不错,感兴趣的朋友一起学习下...

    iVictor1822020-06-19
  • Mysqlmysql 5.7.5 m15 winx64安装配置图文教程

    mysql 5.7.5 m15 winx64安装配置图文教程

    这篇文章主要为大家分享了mysql 5.7.5 m15 winx64安装配置方法图文教程,感兴趣的朋友可以参考一下...

    mysql技术网4722020-06-19
  • MysqlMySQL 基于时间点的快速恢复方案

    MySQL 基于时间点的快速恢复方案

    这篇文章主要介绍了MySQL 基于时间点的快速恢复方案,帮助大家更好的理解和使用MySQL,感兴趣的朋友可以了解下...

    AsiaYe8602021-03-04
  • MysqlMySQL优化GROUP BY方案

    MySQL优化GROUP BY方案

    满足GROUP BY子句的最一般的方法是扫描整个表并创建一个新的临时表,表中每个组的所有行应为连续的,然后使用该临时表来找到组并应用累积函数(如果有...

    hebedich2412020-04-11
  • Mysqlmysql 5.7.10 安装配置方法图文教程

    mysql 5.7.10 安装配置方法图文教程

    这篇文章主要为大家分享了mysql 5.7.10 安装配置方法图文教程,感兴趣的小伙伴们可以参考一下...

    汤高4052020-06-14
  • Mysqlmysql5.7.25使用全文检索功能的实例教程

    mysql5.7.25使用全文检索功能的实例教程

    其实全文检索在MySQL里面很早就支持了,下面这篇文章主要给大家介绍了关于mysql5.7.25使用全文检索功能的相关资料,文中通过实例代码介绍的非常详细,需要的...

    程序猿(攻城狮)5842022-09-19
  • MysqlMySQL 密码增强插件

    MySQL 密码增强插件

    这篇文章主要介绍了MySQL 密码增强插件的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下...

    pursuer.chen5722020-06-16