首先简单介绍一下这两种数据类型:
bigint
从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。
int
从 -2^31 (-2,147,483,648) 到 2^31 – 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。
可以看出bigint的数据类型的范围比int类型的范围足足大了一倍,在我们设计mysql数据库表时,单表规模一般保持在千万级,不会达到22亿上限。如果要加大预留量,可以把主键改为改为无符号int,上限为42亿,这个预留量已经是非常的充足了。
使用bigint,会占用更大的磁盘和内存空间,由于内存空间有限,无效的占用会导致更多的数据换入换出,增加了IO的压力,不利于数据库的性能。所以如果我们使用自增主键bigint类型,可以用int unsigned类型代替,从而优化数据库的性能