mysql中int,bigint,smallint 和 tinyint的区别详细介绍

mysql中int,bigint,smallint 和 tinyint的区别详细介绍,第1张

主要的区别是占用空间和表示范围

tinyint 占用1字节

表示非负: 0-->255

无符号表示:-128-->127

举例表示人的年龄就可以用:age tinyint;

smallint 占用2字节

表示非负:0-->2^16-1 既 0到65535

无符号表示:-2^15-->2^15-1

举例表示乌龟的年龄:agewg smallint;

int 占用4字节

表示非负 0-->2^32-1 既 零到四十二亿九千万

无符号表示:-2^31-->2^31-1

举例表示恐龙化石年龄:agekl int;

bigint 占用8字节

表示非负 0-->2^64-1 这已经是天文数字了,能表示 18后面17个零那么大的数字

无符号表示:-2^63-->2^63-1

bigint比较占用空间,一般都不用。

举例表示宇宙年龄:ageyz bigint;

完全手打亲!

一、所容纳的整形数据不同

1、smallint代表从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。unsigned 是从 0 到 65535 的整型数据。

所以在建表的时候,只能是smallint(5),哪怕建smallint(100),最大还是5位这么多。

2、int代表从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。unsigned 是从 0 到 4294967296 的整型数据。

所以在建表的时候,只能是int(10),哪怕建int(100),最大还是10位这么多。

二、存储大小不同

smallint存储大小为 2 个字节,int存储大小为 4 个字节。

int(M) 在 integer 数据类型中,M 表示最大显示宽度。在 int(M) 中,M 的值跟 int(M) 所占多少存储空间并无任何关系。和数字位数也无关系 int(3)、int(4)、int(8) 在磁盘上都是占用 4 btyes 的存储空间。

扩展资料:

mysql提供了五种整型: tinyint、smallint、mediumint、int和bigint。int为integer的缩写。这些类型在可表示的取值范围上是不同的。

整数列可定义为unsigned从而禁用负值;这使列的取值范围为0以上。各种类型的存储量需求也是不同的。取值范围较大的类型所需的存储量较大。

mysql 提供三种浮点类型: float、double和decimal。与整型不同,浮点类型不能是unsigned的,其取值范围也与整型不同,这种不同不仅在于这些类型有最大值,而且还有最小非零值。

最小值提供了相应类型精度的一种度量,这对于记录科学数据来说是非常重要的(当然,也有负的最大和最小值)。

参考资料来源:

百度百科—int

百度百科—smallint


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5898929.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-07
下一篇 2023-03-07

发表评论

登录后才能评论

评论列表(0条)

保存