用于大型表的MySQL主键列类型

use*_*805 7 mysql database schema database-design

我正在使用相对较大的DB表(700K行)处理该项目.

错误,我在设计数据库架构时做了.当行增加时,我不得不增加ID的列类型bigint(x).

现在它是bigint(44).我害怕设置高x值因为我认为它会显着降低性能.也许我错了..

请帮我解决问题.

我可以设置哪种列类型并忘记此问题?

在数据库架构设计领域我应该学到什么?

Gre*_*reg 14

创建列时,BIGINT(44)"44"是显示宽度 - 它不会影响您可以存储的值范围或检索它们的速度.

对于自动递增ID,您要使用UNSIGNED数字,例如BIGINT(44) UNSIGNED.这将使值的范围加倍并添加额外的约束,这通常是一件好事.

一个未签名的INT将存储最多4,294,967,295一个未签名的BIGINT将存储多达18,446,744,073,709,551,615 - 你不会很快填补它.

你没有说你的最大ID增长有多快 - 如果你没有插入很多行,那么你应该坚持使用,UNSIGNED INT因为它占用的空间更少.