在使用mysql数据库的时候遇到了多种数字的类型,主要有tinyint,smallint,int,bigint这几种类型。

从开发的职场小白到技术大牛,毋庸置疑基本都知道它们最大的区别肯定是长度不同,那么他们有什么区别呢?

1个字符等于8个字节

tinyint

从 -2^7 (-128) 到 2^7 - 1 (123) 的整型数据,unsigned 是从 0 到 2^8 的整型数据,存储大小为 1 字节。

smallint

从 -2^15 (-32,768) 到 2^15 – 1 (32,767) 的整型数据,unsigned 是从 0 到 2^16 的整型数据,存储大小为 2 个字节。

int

从 -2^31 (-2,147,483,648) 到 2^31 – 1 (2,147,483,647) 的整型数据,unsigned 是从 0 到 2^32 的整型数据,存储大小为 4 个字节。

bigint

从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据,unsigned 是从 0 到 2^64 的整型数据,存储大小为 8 个字节。

在支持整数值的地方都可以使用bigint类型的,但不是选择的长度越长越好。就拿人的性别来说,有男女之分,我们完全可以使用tinyint来表示,一个字节就可以搞定了,避免资源的浪费。

一旦数据类型确定好,每个数字在磁盘上占用空间就固定下来,与数值本身大小毫无关系。


杨帆
28 声望3 粉丝