MySQL中int(10)和int (11)有什么区别
这篇文章主要讲解了“MySQL中int(10)和int(11)有什么区别”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL中int(10)和int(11)有什么区别”吧!
mysql 中整数数据类型:
不同类型的取值范围:
不同数据类型的默认v显示宽度:
显示的宽度跟负号没有关系,它只在人工设置了 ZEROFILL 属性有效。一旦人工设置了 ZEROFILL 属性,MySQL 会自动设置 UNSIGNED 属性(即 ZEROFILL 不能存储负数)。
那取值范围和显示宽度到底有什么关系呢?利用 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 最大可能显示的数字个数,数值的位数小于指定的宽度时左侧用数字 0 填充。
如果插入了大于显示宽度的值,只要该值不超过该类型整数的取值范围,数值依然可以插入,而且能够显示出来。
同理,所以 int (10) 和 int (11) 无任何区别,就是显示宽度不同。在存储方面确实没什么不同,设置长度只有在设置了自动填充 ZEROFILL 的时候才体现出来, 比如 id=1 长度为 int (5) 的话会显示 00001。
Mysql 可以为整数类型指定宽度,例如 INT (11),对大多数应用这是没有意义的:他不会限制值的合法范围,只是规定了 Mysql 的一些交互工具,如 Mysql 命令行客户端,用来显示字符的个数。对于存储和运算来说, INT (1) 和 INT (8) 是相同的。
是的,设置自动填充的时候用来显示补充0有点 用而已
感谢各位的阅读,以上就是“MySQL中int(10)和int(11)有什么区别”的内容了,经过本文的学习后,相信大家对MySQL中int(10)和int(11)有什么区别这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是恰卡编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!