MySQL 中 int (10) 和 int (11) 到底有什么区别?
最近在找工作所以一直在面试,在面试过程中暴露了自己很多不足的地方,一直在总结和归纳。可能大部分面试官对mysql的问题都会问数据库优化啊、主从复制啊、索引啊、引擎啊等等之类的。那么使我印象最深的是int(10)和int(11)有什么区别。这好像是最基础的问题了,我好像从来没有在意过。当时有点儿懵逼,有什么区别?不知道!没想过!
那么回到家以后,我赶紧复习了下mysql的数据类型相关知识。对整数类型做些说明。
mysql中整数数据类型
数据类型 | 说明 | 存储需求 |
---|---|---|
tinyint | 很小的整数 | 1字节 |
smallint | 小的整数 | 2字节 |
mediumint | 中等大小的整数 | 3字节 |
int(integer) | 普通大小的整数 | 4字节 |
bigint | 大整数 | 8字节 |
不同类型的取值范围
数据类型 | 有符号 | 无符号 |
---|---|---|
tinyint | -128~127 | 0~255 |
smallint | -32768~32767 | 0~65535 |
mediumint | -8388608~8388607 | 0~16777215 |
int(integer) | -2147483648~2147483647 | 0~4294967295 |
bigint | -9223372036854775808~9223372036854775807 | 0~18446744073709551615 |
不同数据类型的默认显示宽度
数据类型 | 默认显示宽度 |
---|---|
tinyint | 4 |
smallint | 6 |
mediumint | 9 |
int(integer) | 11 |
bigint | 20 |
*因为负号占了一个数字位,所以各类型的宽度是最大值数字位+1位。例如tinyint的最大数字位是3,加负号所以显示宽度是4。
那么取值范围和显示宽度到底有什么关系呢?我利用tinyint做了个实验,首先创建一张表如下
mysql> desc test_integer;
+-----------+------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------+------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| test_id_1 | tinyint(1) | NO | | NULL | |
| test_id_2 | tinyint(4) | NO | | NULL | |
+-----------+------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)
我分别创建了有符号tinyint类型的test_id_1显示宽度为1和test_id_2显示宽度为4两字段,接下来插入数据,同时插入-128、1和127这些数值,看看会怎么样。
mysql> insert into test_integer (test_id_1,test_id_2) values (-128,-128), (1,1), (127,127);
Query OK, 3 rows affected (0.00 sec)
Records: 3 Duplicates: 0 Warnings: 0
ok提示插入成功,我们查询一下
mysql> select * from test_integer;
+----+-----------+-----------+
| id | test_id_1 | test_id_2 |
+----+-----------+-----------+
| 1 | -128 | -128 |
| 2 | 1 | 1 |
| 3 | 127 | 127 |
+----+-----------+-----------+
3 rows in set (0.00 sec)
查询出来的结果也是一样,经过以上实验得到结论:
显示宽度整数类型的取值范围是无关的。显示宽度只是指明mysql最大可能显示的数字个数,数值的位数小于指定的宽度时就由空格填充,如果插入了大于显示宽度的值,只要该值不超过该类型整数的取值范围,数值依然可以插入,而且能够显示出来。
同理,所以int(10)和int(11)没有任何区别,就是显示宽度不同,小伙伴们千万不要忘记了呀。
本作品采用《CC 协议》,转载必须注明作者和本文链接
在存储方面确实没什么不同,设置长度只有在设置了自动填充 ZEROFILL 的时候才体现出来, 比如 id=1 长度为 int(5) 的话会显示 00001
int(11)事实上没意义啊,int宽度不是最大是10吗,11设置了没什么意义,我是这么理解,不知道有没有错
Mysql 可以为整数类型指定宽度,例如 INT(11),对大多数应用这是没有意义的:他不会限制值的合法范围,只是规定了 Mysql 的一些交互工具,如 Mysql 命令行客户端,用来显示字符的个数。对于存储和运算来说, INT(1) 和 INT(8) 是相同的。
@Herbie 1. “因为负号占了一个数字位,所以各类型的宽度是最大值数字位 + 1 位。例如 tinyint 的最大数字位是 3,加负号所以显示宽度是 4”,说法有误。 原因:显示的宽度跟负号没有关系,它只在人工设置了ZEROFILL属性有效。一旦人工设置了ZEROFILL属性,MySQL会自动设置UNSIGNED属性(即ZEROFILL不能存储负数) 2.“数值的位数小于指定的宽度时就由空格填充”,说法有误。应该是:数值的位数小于指定的宽度时左侧用数字0填充。
输入 int 的话,默认设置的就是 int(11)