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)来表示这是老数据,那么数字型主键面临一个挑战
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

旷野历程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值