首页 > 教程 >
在 MySQL 中 int (10) 和 int (11) 的区别
2023-02-15教程围观次
简介开发中不免会经常建立数据库,这里经常会设置字段为int(10)或int(11)有什么区别。但这两者有什么区别呢,我好像从来没有在意过。于是赶紧复习了下mysql的数据类型相关知识。对整数类型做些说明。mysql中整数数据类型数据类型说明存储需求tinyint很小的整数1字节smallint小的整数2字节mediumint中等大小的整数3字节int(integer)普通大小的整数4字节bigint大
开发中不免会经常建立数据库,这里经常会设置字段为 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) 没有任何区别,就是显示宽度不同,小伙伴们千万不要忘记了呀。
以上就是在 MySQL 中 int (10) 和 int (11) 的区别的详细内容,希望大家学习后能不断进步。
下载链接:网站源码/小程序源码/网站模板下载
上一篇:PHP如何将数组下标去掉
下一篇:MySQL 日期加减函数汇总
相关文章
- php浮点数float运算中转整型int问题
- Laravel使用intervention image包上传、剪裁图片
- Nginx internal指令限制直接访问服务器文件
- node mysql 小程序源码 nodejs连接数据库
- 使用PHP+ajax+mysql+layui实现每日签到及提醒功能
- PHP使用mysqli同时执行多条sql查询语句的实例
- 提高mysql千万级大数据SQL查询优化30条经验(Mysql索引优化注意)
- Mysql报错“Incorrect key file for table” 数据库表显示“使用中”解决办法
- 宝塔面板 - 通过宝塔面板安装的mysql 默认密码是什么
- 服务器硬盘空间不足导致MySQL异常的一系列问题及解决办法
下载排行
- 最新版去水印小程序源码/基于WordPress的短视频去水印小程序源码
- 某鱼最近卖的很火蓝色版微信去水印小程序源码+接口
- 最新短视频去水印小程序源码/带流量主/外卖CPS系统/批量解析/修改MD5
- 帝国CMS仿管理资源吧资料下载网站模板源码/下载会员+积分付费下载功能自动采集资源网站源码
- 苹果CMS二次元慕乔JOELEO模板/精美UI手机版影视模板
- 文案馆头像壁纸小程序源码+带后台
- 最新去水印小程序源码分享/无需后台/对接接口/支持全网去水印功能
- 知识付费小程序源码升级版知识付费变现小程序源码+卡密-独立后台版本
- 爱看小说网源码全站带数据打包/ThinkPHP内核小说网站源码
- 新版多功能去水印工具微信小程序源码下载+带流量主功能