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


本文摘自PHP中文网,作者Guanhui,侵删。

最近在找工作所以一直在面试,在面试过程中暴露了自己很多不足的地方,一直在总结和归纳。可能大部分面试官对 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 做了个实验,首先创建一张表如下

1

2

3

4

5

6

7

8

9

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 这些数值,看看会怎么样。

1

2

3

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 提示插入成功,我们查询一下

1

2

3

4

5

6

7

8

9

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教程》

以上就是在 MySQL 中 int (10) 和 int (11) 的区别的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

mysql怎么根据date做年,月,日分组统计查询

mysql如何远程连接端口并修改

关于mysql优化之in换inner join的实例分享

mysql connectors是什么

怎么设置开机自启动mysql

mysql数据迁徙方法工具解析

windows系统的mysql服务怎么开

mysql的root密码如何重置

mysql全文索引实现简单版搜索引擎实例代码

mysql数据库进行连接的简单示例代码

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...