mysql int(m)与int(m)的差别

预计大多数開始接触mysql的朋友们都会有这个问题:int(M) 里面的数值究竟是什么意思?

依据相关资料总结了下:

int(M) zerofill,加上zerofill后M才表现出有点点效果,比方 int(3)
zerofill,你插入到数据库里的是10,则实际插入为010,也就是在前面补充加了一个0.假设int(3)和int(10)不加zerofill,则它们没有什么差别.M不是用来限制int个数的.int(M)的最大值和最小值与undesigned有关,最以下那副图有说明.

mysql> create table table_one (t int(3) zerofill);

Query OK, 0 rows affected (0.00 sec)

mysql> insert into
table_one set t = 8;

Query OK, 1 row affected (0.00 sec)

mysql> select * from
table_one ;

+——+

| t |

+——+

| 008 |

+——+

1 row in set (0.11 sec)

Zerofill with default width, the same as int(10):

mysql> create table table_two (t int zerofill);

Query OK, 0 rows affected (0.02 sec)

mysql> insert into
table_two  set t = 10;

Query OK, 1 row affected (0.02 sec)

mysql> select * from t;

+————+

| t |

+————+

| 0000000010 |

+————+

1 row in set (0.08 sec)

Without zerofill:

mysql> create table
table_3 (t int);

Query OK, 0 rows affected (0.01 sec)

mysql> insert into
table_3 set t = 10;

Query OK, 1 row affected (0.01 sec)

mysql> select * from t;

+——+

| t |

+——+

| 10 |

+——+

1 row in set (0.00 sec)

1 bytes = 8 bit ,一个字节最多能够代表的数据长度是2的8次方 11111111 在计算机中也就是

-128到127

1.BIT[M]

位字段类型。M表示每一个值的位数。范围从1到64,假设M被忽略。默觉得1

2.TINYINT[(M)] [UNSIGNED] [ZEROFILL]  M默觉得4

非常小的整数。带符号的范围是-128到127。无符号的范围是0到255。

3. BOOL,BOOLEAN

是TINYINT(1)的同义词。

zero值被视为假。非zero值视为真。

4.SMALLINT[(M)] [UNSIGNED] [ZEROFILL] M默觉得6

小的整数。带符号的范围是-32768到32767。

无符号的范围是0到65535。

5.MEDIUMINT[(M)] [UNSIGNED] [ZEROFILL] M默觉得9

中等大小的整数。带符号的范围是-8388608到8388607。

无符号的范围是0到16777215。

6. INT[(M)] [UNSIGNED] [ZEROFILL]   M默觉得11

普通大小的整数。带符号的范围是-2147483648到2147483647。无符号的范围是0到4294967295。

7.BIGINT[(M)] [UNSIGNED] [ZEROFILL] M默觉得20

大整数。带符号的范围是-9223372036854775808到9223372036854775807。无符号的范围是0到18446744073709551615。

*:这里的M代表的并非存储在数据库中存储的详细的长度

事实上当我们在选择使用int的类型的时候,不论是int(3)还是int(11)。它在数据库里面存储的都是4个字节的长度。在使用int(3)的时候假设你输入的是10。会默认给你存储位010,也就是说这个3代表的是默认的一个长度,当你不足3位时,会帮你不全,当你超过3位时,就没有不论什么的影响。

前天组管问我 int(10)与int(11)有什么差别。当时认为就是长度的差别吧,如今看,他们之间除了在存储的时候略微有点差别外。在我们使用的时候是没有不论什么差别的。int(10)也能够代表2147483647这个值int(11)也能够代表。

我们通常在创建数据库的时候都不会增加这个选项,所以能够说他们之间是没有差别的。

时间: 2024-11-09 00:21:30

mysql int(m)与int(m)的差别的相关文章

mysql中int(1)与int(10)的区别

INT[(M)] [UNSIGNED] [ZEROFILL] 普通大小的整数.带符号的范围是-2147483648到2147483647.无符号的范围是0到4294967295. INT(1) 和 INT(10)本身没有区别,但是加上(M)值后,会有显示宽度的设置. 如代码所示: mysql> create table test(id int(3)); Query OK, 0 rows affected (0.47 sec) mysql> insert into test values(12)

mysql int(3)与int(11)的区别

总结,int(M) zerofill,加上zerofill后M才表现出有点点效果,比如 int(3) zerofill,你插入到数据库里的是10,则实际插入为010,也就是在前面补充加了一个0.如果int(3)和int(10)不加zerofill,则它们没有什么区别.M不是用来限制int个数的.int(M)的最大值和最小值与undesigned有关,最下面那副图有说明. mysql> create table t (t int(3) zerofill);Query OK, 0 rows affe

关于mysql中int(1)中int后面的数字

详解mysql int类型的长度值问题 作者:追逐_something 我的朋友海滨问我mysql在建表的时候int类型后的长度代表什么? 是该列允许存储值的最大宽度吗? 为什么我设置成int(1), 也一样能存10,100,1000呢. 当时我虽然知道int(1),这个长度1并不代表允许存储的宽度,但却没有一个合理的解释. 或者说对这个长度也没有真正的研究过到底代表什么, 平时都用int(11), 也不知道为什么要11位. 所以我在网上查阅了一些资料, 也仔细的看了mysql手册关于int d

MySQL数据库数据类型以及INT(M)的含义

nt(M)我们先来拆分,int是代表整型数据那么中间的M应该是代表多少位了,后来查mysql手册也得知了我的理解是正确的,下面我来举例说明. MySQL 数据类型中的 integer types 有点奇怪.你可能会见到诸如:int(3).int(4).int(8) 之类的 int 数据类型.刚接触 MySQL 的时候,我还以为 int(3) 占用的存储空间比 int(4) 要小, int(4) 占用的存储空间比 int(8) 小. 后来,参看 MySQL 手册,发现自己理解错了.  代码如下 复

mysql中timestamp,datetime,int类型的区别与优劣

mysql中timestamp,datetime,int类型的区别与优劣 int 1. 占用4个字节 2. 建立索引之后,查询速度快 3. 条件范围搜索可以使用使用between 4. 不能使用mysql提供的时间函数 结论:适合需要进行大量时间范围查询的数据表 datetime 1. 占用8个字节 2. 允许为空值,可以自定义值,系统不会自动修改其值. 3. 实际格式储存(Just stores what you have stored and retrieves the same thing

mysql数据类型——整型INT(m)

1.整形分为四种 tinyint smallint mediumint int bigint 注意: 右侧的取值范围是在未加unsigned关键字的情况下,如果加了unsigned,则最大值翻倍,如tinyint unsigned的取值范围为(0~256). 项目出错案例: 在做根据身份获取城市的时候 发现大于127的region_id 就都取127得127( 东方市),一直找不到原因,原来是插入region_id的字段类型定义问题 定义为: tinyint(4) 最大127 若加上unsign

mysql int(m)与int(m)的区别

估计大多数开始接触mysql的朋友们都会有这个问题:int(M) 里面的数值到底是什么意思? 根据相关资料总结了下: int(M) zerofill,加上zerofill后M才表现出有点点效果,比如 int(3) zerofill,你插入到数据库里的是10,则实际插入为010,也就是在前面补充加了一个0.如果int(3)和int(10)不加zerofill,则它们没有什么区别.M不是用来限制int个数的.int(M)的最大值和最小值与undesigned有关,最下面那副图有说明. mysql>

mysql int(10)和int(11)区别

先说结论,对于存储和计算来说,int(10)和int(11)没有区别,10代表数字长度,但是int类型占用4个字节,取值范围是-2147483648~2147483647,也就是最大长度是10,如果写成int(11), 插入11位数的时候是插入不进去的,mysql会默认int最大10位(2147483647),2147483648也将插入不了.所以int(1)和int(20)是没有区别的,但是写int(20)会认为对mysql字段类型理解不到位.但是TINYINT和INT区别就大了,TINYIN

int *p,cons int *p,int const *p,int * const p,const int * const p,int const * const p的差别

?? 加有constkeyword的几种情况的辨析 const修饰的代码 含义(特点) 等价性 int *p = # 1.       能够读自己 2.       能够通过*p改自己 3.       能够通过p = &data来看别人 权限最大 cons int *p = # 1.const放在左边意味着指向的是常量.这个常量不能够改动, 2.p = &data; (地址能够改动) 3.*p = 30;(这个时候是错误的) 这两者等价(应用:查看别人的账