简介开发中不免会经常建立数据库,这里经常会设置字段为int(10)或int(11)有什么区别。但这两者有什么区别呢,我好像从来没有在意过。于是赶紧复习了下mysql的数据类型相关知识。对整数类型做些说明。mysql中整数数据类型数据类型说明存储需求tinyint很小的整数1字节smallint小的整数2字节mediumint中等大小的整数3字节int(integer)普通大小的整数4字节bigint大
开发中不免会经常建立数据库,这里经常会设置字段为 int (10) 或 int (11) 有什么区别。但这两者有什么区别呢,我好像从来没有在意过。
于是赶紧复习了下 mysql 的数据类型相关知识。对整数类型做些说明。
mysql 中整数数据类型
不同类型的取值范围
不同数据类型的默认显示宽度
* 因为负号占了一个数字位,所以各类型的宽度是最大值数字位 + 1 位。例如 tinyint 的最大数字位是 3,加负号所以显示宽度是 4。
那么取值范围和显示宽度到底有什么关系呢?我利用 tinyint 做了个实验,首先创建一张表如下
mysql>desctest_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||+-----------+------------+------+-----+---------+----------------+3rowsinset(0.00sec)
我分别创建了有符号 tinyint 类型的 test_id_1 显示宽度为 1 和 test_id_2 显示宽度为 4 两字段,接下来插入数据,同时插入 – 128、1 和 127 这些数值,看看会怎么样。
mysql>insertintotest_integer(test_id_1,test_id_2)values(-128,-128),(1,1),(127,127);QueryOK,3rowsaffected(0.00sec)Records:3Duplicates:0Warnings:0
ok 提示插入成功,我们查询一下
mysql>select*fromtest_integer;+----+-----------+-----------+|id|test_id_1|test_id_2|+----+-----------+-----------+|1|-128|-128||2|1|1||3|127|127|+----+-----------+-----------+3rowsinset(0.00sec)
查询出来的结果也是一样,经过以上实验得到结论:
显示宽度整数类型的取值范围是无关的。显示宽度只是指明 mysql 最大可能显示的数字个数,数值的位数小于指定的宽度时就由空格填充,如果插入了大于显示宽度的值,只要该值不超过该类型整数的取值范围,数值依然可以插入,而且能够显示出来。
同理,所以 int (10) 和 int (11) 没有任何区别,就是显示宽度不同,小伙伴们千万不要忘记了呀。
以上就是在 MySQL 中 int (10) 和 int (11) 的区别的详细内容,希望大家学习后能不断进步。
下载链接:网站源码/小程序源码/网站模板下载