MySQL字段类型tinyint、smallint、mediumint、int、bigint

郎家岭伯爵 2023年02月15日 449次浏览

背景

MySQL 中整型字段详解。

理论

先来看一下基本的概念:字节(byte),1个字节等于8个位(bit),一个 bit 存储 0 或者 1,理解这个对于理解后面的占用字节导致的存储数值的有很重要的作用。

整型,常见细分为 tinyint、smallint、mediumint、int、bigint 这几种。

  • tinyint:存储所占一个字节,一个字节等于 8bit,1bit 可以存储 0 到 1 两种可能性,因此 tinyint 类型可以存储 2 的 8 次方,也就是 256 种可能性。从 0 开始计数,无符号也就是可以存储 0~255,如果是有符号,那就是 -128~127。

  • smallint:存储所占两个字节,同上也就是可以存储 2 的 16 次方,也就是可以存储 65536 种可能性,无符号从 0 开始则是可以存储 0~65535,有符号则是 -32768~32767。

  • mediumint:存储所占三个字节,也就是 2 的 24 次方,可以存储 16777216 种可能性,无符号可以存储 0~16777215,有符号可以存储 -8388608~8388607。

  • int:存储所占四个字节,也就是 2 的 32 次方,可以存储 4294967296 种可能性,无符号可以存储 0~4294967295,有符号则是 -2147483648~2147483647。

  • bigint:存储所占八个字节,也就是 2 的 64 次方,可以存储 2 的 64 次种可能性,无符号可以存储 0~((2³²×²)-1),有符号则是 -(2³²×²)/2 ~ (2³²×²)/2-1。

我们经常会见到 int(11)、tinyint(1) 这种后面跟括号里面放数字的情况,很多人以为这是代表的该类型可存储的长度,但是我们上面已经分析了存储的情况,这种理解肯定是不对的。实际上括号里的数字表示的是最大显示宽度,这个数字和存储大小及其类型没有任何关系。就是说 tinyint(1) 和 tinyint(3) 都是存储一个字节,并不会因为括号里的数字改变,这个数字仅仅是显示最大宽度。

例如:tinyint(3) 存储 11 则会显示 011,因为最大宽度为 3,达不到的情况下用 0 来补充,这样的话就很好理解了。

CREATE TABLE int_test (
id int(11) NOT NULL AUTO_INCREMENT,
intdemo int(3) ZEROFILL DEFAULT NULL,  
PRIMARY KEY(id)
);

在设置这个括号里的数值时我们也要小心,因为 MySQL 手册上明确写了:当 MySQL 为某些复杂的联结(join)生成临时表时,可能会遇到问题,因为在这种情况下,MySQL 信任地认为所有的值均适合原始的列宽度。

总结

MySQL 中整型字段详解。