MySQL中Int(3)与Int(6)的数值范围相同吗?

运维 数据库运维
int类型整数占4个字节,有符号的范围为:-2^31 ~ 2^31-1,无符号整数范围为:0 ~ 2^32-1,既然都是无符号整数,那么存储范围是一样的,int(6)只是在数字不够6位时用0补全,如果超过6位,则不需要补全。

[[427909]]

本文转载自微信公众号「大数据技术派」,作者柯柯。转载本文请联系大数据技术派公众号。

提问:

mysql的字段,unsigned int(3), 和unsinged int(6), 能存储的数值范围是否相同。如果不同,分别是多大?

回答:

不同,int(3)最多显示3位无符号整体,int(6)最多显示6位无符号数。

如果你的答案和上面的一致,恭喜你和我犯了一样的错误。

真实情况:

int类型整数占4个字节,有符号的范围为:-2^31 ~ 2^31-1,无符号整数范围为:0 ~ 2^32-1,既然都是无符号整数,那么存储范围是一样的,int(6)只是在数字不够6位时用0补全,如果超过6位,则不需要补全。

我们建立下面这张表:

  1. drop table if exists test; 
  2. CREATE TABLE `test` ( 
  3.   `id` int(11) NOT NULL AUTO_INCREMENT, 
  4.   `a` int(11) NOT NULL
  5.   `b` int(11) unsigned zerofill NOT NULL
  6.   `c` int(5) DEFAULT NULL
  7.   `d` int(5) unsigned zerofill NOT NULL
  8.   `e` int(15) DEFAULT NULL
  9.   PRIMARY KEY (`id`) 
  10. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; 

插入一些数据后,用cmd命令行查看:

  1. mysql> select * from test; 
  2. +----+------------+-------------+------------+------------+------------+ 
  3. | id | a          | b           | c          | d          | e          | 
  4. +----+------------+-------------+------------+------------+------------+ 
  5. |  1 |          1 | 00000000001 |          1 |      00001 |          1 | 
  6. |  2 | 1234567890 | 01234567890 | 1234567890 | 1234567890 | 1234567890 | 
  7. +----+------------+-------------+------------+------------+------------+ 

发现,无论是int(3), int(6), 都可以显示6位以上的整数。但是,当数字不足3位或6位时,前面会用0补齐。

注意:如果你是用类似navicat这种工具看,不会补充0,可能做了处理,需要用mysql cmd命令行才能看到这种效果。

查下手册,解释是这样的:

MySQL还支持选择在该类型关键字后面的括号内指定整数值的显示宽度(例如,INT(4))。该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。显示宽度并不限制可以在列内保存的值的范围,也不限制超过列的指定宽度的值的显示。

也就是说,int的长度并不影响数据的存储精度,长度只和显示有关,为了让大家看的更清楚,我们在上面例子的建表语句中,使用了zerofill。

结论:

无论是unsigned int(3)或 unsiend int(6),存储的都是4字节无符号整数, 也就是0~2^32。

 

责任编辑:武晓燕 来源: 大数据技术派
相关推荐

2024-03-14 08:36:25

MySQLzerofill​数字

2024-01-29 10:09:59

数据库INT(3)INT(11)

2010-10-08 14:45:43

mysql中int

2021-08-30 07:22:15

Go类型interface

2010-10-08 14:04:44

MySQL数值数据类型

2023-02-07 09:01:30

字符串类型MySQL

2021-07-27 06:49:11

数据库设计数据

2023-12-12 08:50:22

MySQL隐式转换varchar

2009-06-19 16:46:18

IntegerJava

2024-03-19 14:18:48

C#后端编程

2022-09-09 15:32:46

intC语言原子操作

2022-07-01 11:07:56

int原子操作代码

2010-11-22 11:25:07

MySQL查询时间段

2009-08-18 15:00:00

C#强制转换

2009-08-03 14:54:23

值类型C#

2023-09-14 16:02:27

2021-09-23 14:55:57

.NETHTTP服务器

2021-08-06 07:51:47

关键字int函数

2024-09-11 15:59:31

LLM.int8()大模型量化

2022-05-16 07:48:54

Python操作类型
点赞
收藏

51CTO技术栈公众号