MySQL主键类型使用int、bigint、varchar区别

范围

int:从 -2^31 (-2147483648) 到 2^31-1 (2147483647) 的整型数据。

bigint:从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据。

准备三张表,以200w条数据为基础,除了id的类型外其他都一样。

table1:主键为 int 类型

table2:主键为 bigint 类型

table3:主键为 varchar 类型

在执行相同的操作后得出以下结论:

  • 查询速度不同,int > bigint > varchar
  • 占用磁盘空间不同,int 存储大小为  4 个字节;bigint 存储大小为 8 个字节。 int < bigint < varchar
  • 如果主键值大于字段类型的范围时,MySQL 会报错:out of range value for column ‘id‘ at row 1。如:在 int 类型的字段中存储超过 10 位的值时,就会提示上边的错误。
  • 不同的字段类型存储数据容量也个不相同
  • 若系统是数字型,在导入时,为了区分新老数据,可能想在老数据主键前统一加一个字符标识(例如“o”,old)来表示这是老数据,那么数字型主键面临一个挑战

你可能感兴趣的:(#,MySQL,mysql,数据库,java)