在使用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来表示,一个字节就可以搞定了,避免资源的浪费。
一旦数据类型确定好,每个数字在磁盘上占用空间就固定下来,与数值本身大小毫无关系。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。