互联网大厂面试:MySQL中int(11)和int(10)有什么区别?

数据库 MySQL
对于字符串类型的定义name varchar(20),我们可以清楚的知道,这是表示name这个字段最大长度是20个字符,当name字段的长度超过20字符时,MySQL就会报错。

我们在平时创建MySQL表时,会指定各种字段的类型,比如id int(11),name varchar(20)。

那不知道大家细想过没有,int(11)和int(10)有什么区别呢?存储的数值范围有什么不一样吗?​

对于字符串类型的定义name varchar(20),我们可以清楚的知道,这是表示name这个字段最大长度是20个字符,当name字段的长度超过20字符时,MySQL就会报错。

那么对于int类型来说,当定义为无符号int时,最大取值范围是4294967295,数一下长度也就10位,那么难道我们定义int(11)的时候,可以突破int类型的取值上限了吗?

另外有些细心的朋友可能会发现,我们在创建表时,如果没有指定int类型的length,MySQL会自动帮我们指定length为int(10)。如果我们指定了int(x),那么length就会被定义为x。

其实,对于int类型来说,其最大值和最小值都是固定的,定义的int(x)中x代表的并不是长度,而是显示宽度。

当定义一个无符号int类型,且设置了ZEROFILL属性时,如果数值的长度没有达到显示的宽度时,MySQL会自动的在数值前面补零直至达到定义的宽度。

我们新建一个表test验证一下。

大家可以看到我将id的length定义为了8,这是为了让大家看到当存储的数值超过8的显示结果。desc查看表结构如下:

我们插入两条数据,看一下具体的显示效果。


两条记录的主键分别为1和10001000,select看一下MySQL是如何显示的。

可以看到,第一条记录,由于显示的宽度只有1,MySQL对其在左边补了7个0,

而对于第二条记录,其显示宽度是8,MySQL没有做什么改变。

也就说,当存储的数据宽度不够时,MySQL才会在左边补零。

那么问题又来了,MySQL引擎在存储数据的时候,存的是1呢,还是00000001呢?

很明显,存储的是1,00000001只是用来给我们显示用的。

另外需要大家注意的是,zerofill填充只对正数起作用,因为ZEROFILL属性会隐式地将数值转为无符号型

所以总结一下就是,int(x)中的x代表是其宽度,其宽度值并不会影响存储的范围,而只是根据定义的宽度进行了显示的格式化而已。

而int类型宽度可以定义的范围是多少呢?-1~10485760。

最后,再问大家一个问题吧,宽度的格式化是MySQL的Server来做的,还是InnoDB引擎做的呢?

责任编辑:姜华 来源: 今日头条
相关推荐

2021-04-26 05:36:59

物联网

2022-08-31 16:17:21

造芯互联网公司大厂

2021-12-16 10:32:04

APP会员互联网大厂用户

2023-03-07 08:22:34

MySQL优化器

2022-01-05 16:45:22

互联网裁员危机

2020-12-30 05:36:59

分库分表存储

2023-01-17 09:41:26

Redis接口限流

2021-12-14 15:27:48

互联网程序员裁员

2022-06-01 20:24:25

互联网元宇宙大厂

2020-02-23 17:39:21

互联网复工公司

2019-10-25 15:50:06

MySQL数据库命令

2023-05-02 22:38:46

JVMJVM调优

2022-02-24 11:05:06

互联网加班科技

2021-11-22 10:03:47

互联网薪资技术

2018-08-23 09:06:18

互联网百度面试

2020-07-19 10:06:02

互联网数据技术

2022-01-24 10:46:40

互联网裁员

2021-06-28 08:57:29

快手腾讯员工

2022-08-22 07:06:32

MyBatisSQL占位符

2014-11-24 11:20:20

互联网
点赞
收藏

51CTO技术栈公众号