欢迎来到站长教程网!

PHP教程

当前位置:主页 > 网络编程 > PHP教程 >

在 MySQL 中 int (10) 和 int (11) 的区别

时间:2020-05-20|栏目:PHP教程|点击:

在 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) 没有任何区别,就是显示宽度不同,小伙伴们千万不要忘记了呀。

上一篇:深入理解依赖注入是如何实现解耦

栏    目:PHP教程

下一篇:PHP结合AJAX实现搜索提示功能

本文标题:在 MySQL 中 int (10) 和 int (11) 的区别

本文地址:http://www.blue1000.com/wangluobiancheng/PHPjiaocheng/1308.html

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:1961407250 | 邮箱:1961407250#qq.com(#换成@)

Copyright © 2002-2022 BK网络学院版权所有 Power by DedeCms 粤ICP备19027147号-7