当前位置:首页 > 科技  > 软件

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

来源: 责编: 时间:2024-02-01 12:52:16 196观看
导读最近在网上看到一篇关于int(3)和int(11)区别的帖子,我第一反应这不就是它们之间主要涉及存储整型数据时所需的位数,即3位和11位的差异。然而,经过详细阅读文章并进行进一步的资料查询和测试后,我才发现我一直以来对于int(

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

图片mysql-int.jpglSN28资讯网——每日最新资讯28at.com

MYSQL int 数据存储范围

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

显示宽度

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

我们可以在mysql(5.7)中创建数据查看下具体的效果:lSN28资讯网——每日最新资讯28at.com

创建表:lSN28资讯网——每日最新资讯28at.com

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

添加数据:lSN28资讯网——每日最新资讯28at.com

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

查看数据:lSN28资讯网——每日最新资讯28at.com

图片图片lSN28资讯网——每日最新资讯28at.com

_20240127224156.jpglSN28资讯网——每日最新资讯28at.com

可以看到,int() 括号中的数字是在位数不足时如果使用ZEROFILL的话会在前面用零进行填充,补齐到括号中数字的位数。lSN28资讯网——每日最新资讯28at.com

注意事项

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

因为ZEROFILL属性只适用于非负整数。所以当我们插入负数时会报错。lSN28资讯网——每日最新资讯28at.com

图片图片lSN28资讯网——每日最新资讯28at.com

我们打开表的DDl,就可以看到,我们设置ZEROFILL的时候他会自动设置为unsigned(无符号)lSN28资讯网——每日最新资讯28at.com

图片图片lSN28资讯网——每日最新资讯28at.com

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

实际应用

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

总结

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

本文链接:http://www.28at.com/showinfo-26-70479-0.html你对MySQL的int(11)真的了解吗?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Java中的并发编程模型及其应对策略

下一篇: 面试官:说一下零拷贝技术的实现原理?

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • K60 Pro官方停产 第三方瞬间涨价

    虽然没有官方宣布,但Redmi的一些高管也已经透露了,Redmi K60 Pro已经停产且不会补货,这一切都是为了即将到来的K60 Ultra铺路,属于厂家的正常操作。但有意思的是该机在停产之后
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • 六大权益!华为8月服务日开启:手机免费贴膜、维修免人工费

    8月5日消息,一年一度的华为开发者大会2023(Together)日前在松山湖拉开帷幕,与此同时,华为8月服务日也式开启,到店可享六大专属权益。华为用户可在华为商城Ap
  • 8月总票房已突破10亿!《封神》第一:口碑已经成了

    8月5日消息,据灯塔专业版数据,截至8月5日9时35分,8月总票房(含预售)已突破10亿。其中,《封神》以大比分的优势领先。根据官方消息,目前该片总票房已经超过14.
  • 企业采用CRM系统的11个好处

    客户关系管理(CRM)软件可以为企业提供很多的好处,从客户保留到提高生产力。  CRM软件用于企业收集客户互动,以改善客户体验和满意度。  CRM软件市场规模如今超过580
  • 使用Webdriver-manager解决浏览器与驱动不匹配所带来自动化无法执行的问题

    1、前言在我们使用 Selenium 进行 UI 自动化测试时,常常会因为浏览器驱动与浏览器版本不匹配,而导致自动化测试无法执行,需要手动去下载对应的驱动版本,并替换原有的驱动,可能还
  • 破圈是B站头上的紧箍咒

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之每年的暑期档都少不了瞄准追剧女孩们的古偶剧集,2021年有优酷的《山河令》,2022年有爱奇艺的《苍兰诀》,今年却轮到小破站抓住了追
  • 华为开发者大会2023日程公开:开设鸿蒙HarmonyOS 4体验区

    IT之家 7 月 31 日消息,华为今日公布了 HDC.Together 开发者大会 2023 的详细日程。整场大会将于 8 月 4 日-6 日之间举行,届时将发布最新一代鸿蒙 H
Top