站长图库

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

 发布时间 2020-05-20 21:10:17 热度 79

 Tag标签:  MySQL

开发中不免会经常建立数据库,这里经常会设置字段为 int (10) 或 int (11) 有什么区别。但这两者有什么区别呢,我好像从来没有在意过。

于是赶紧复习了下 mysql 的数据类型相关知识。对整数类型做些说明。


mysql 中整数数据类型

数据类型说明存储需求
tinyint很小的整数1 字节
smallint小的整数2 字节
mediumint中等大小的整数3 字节
int(integer)普通大小的整数4 字节
bigint大整数8 字节

不同类型的取值范围

数据类型有符号无符号
tinyint-128~1270~255
smallint-32768~327670~65535
mediumint-8388608~83886070~16777215
int(integer)-2147483648~21474836470~4294967295
bigint-9223372036854775808~92233720368547758070~18446744073709551615

不同数据类型的默认显示宽度

数据类型默认显示宽度
tinyint4
smallint6
mediumint9
int(integer)11
bigint20

* 因为负号占了一个数字位,所以各类型的宽度是最大值数字位 + 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) 没有任何区别,就是显示宽度不同,小伙伴们千万不要忘记了呀。


以上就是在 MySQL 中 int (10) 和 int (11) 的区别的详细内容,希望大家学习后能不断进步。


评论(0)条

    站长图库

    站长素材 - 建站资源分享平台

    猜你喜欢
    个人主页博客网页设计PSD网页模板素材

    个人主页博客网页设计PSD网页模板素材

    网页模板 109 2020-01-23

    个人主页博客网页设计PSD网页模板素材,适用于个人主页设计、博客界面设计使用。

    CSS3邮件收件箱列出邮件特效

    CSS3邮件收件箱列出邮件特效

    其他 123 2020-02-12

    CSS3邮件收件箱列出邮件特效是一款以简洁的列表方式列出所有的邮件,当用户点击相应的邮件时会以动画的方式弹出该邮件的详细...

    PHP仿A8音乐分享网站源码下载/适合做类似于音悦台音乐播放平台

    PHP仿A8音乐分享网站源码下载/适合做类似于音悦台音乐播放平台

    其他源码 923 2018-10-25

    PHP仿A8音乐分享网站源码 带会员功能,适合做类似于音悦台、酷我等在线音乐播放平台。源码使用php+MySQL,程序开...

    AI民族秀 V1.0.5 原版 微擎功能模块

    AI民族秀 V1.0.5 原版 微擎功能模块

    微信源码 253 2019-10-10

    AI民族秀 V1.0.5 原版 微擎功能模块核心功能:1、自定义活动名称,无限生成子活动2、自定义顶部广告区域...