问题:尽管 BIGINT 看起来是 MySQL 最大的整数类型,但是存储更大整数的解决方案是什么?说 BIGINT(80)?此外,为什么某些来源(例如 Twitter 的 API 文档)建议将这些大整数存储为 varchar?哪些因素会影响这些数据类型之间的选择?
答案:
与直觉相反的是,大整数的 64 位大小限制(而不是特定的位数 20) )确定它们的实际边界。任何超过此 64 位限制的数字都无法容纳在大整数内。
此限制是由于本机整数针对硬件的闪电般快速操作进行了优化,而数字的文本表示通常需要顺序逐位处理方法。
如果遇到超过 64 位限制的数字,可以选择 varchar 存储。然而,这种方法有一个警告:对这些存储的数字进行广泛的数学运算可能不可行。
或者,您可以探索:
以上是如何处理超出 MySQL BIGINT 限制的大量整数:Varchar 与其他选项?的详细内容。更多信息请关注PHP中文网其他相关文章!