首页  >  文章  >  数据库  >  如何处理超出 MySQL BIGINT 限制的大量整数:Varchar 与其他选项?

如何处理超出 MySQL BIGINT 限制的大量整数:Varchar 与其他选项?

Patricia Arquette
Patricia Arquette原创
2024-10-23 23:20:30796浏览

How to Handle Massive Integers Beyond MySQL's BIGINT Limit: Varchar vs. Other Options?

处理超出 MySQL 限制的海量整数

问题:尽管 BIGINT 看起来是 MySQL 最大的整数类型,但是存储更大整数的解决方案是什么?说 BIGINT(80)?此外,为什么某些来源(例如 Twitter 的 API 文档)建议将这些大整数存储为 varchar?哪些因素会影响这些数据类型之间的选择?

答案:

与直觉相反的是,大整数的 64 位大小限制(而不是特定的位数 20) )确定它们的实际边界。任何超过此 64 位限制的数字都无法容纳在大整数内。

此限制是由于本机整数针对硬件的闪电般快速操作进行了优化,而数字的文本表示通常需要顺序逐位处理方法。

如果遇到超过 64 位限制的数字,可以选择 varchar 存储。然而,这种方法有一个警告:对这些存储的数字进行广泛的数学运算可能不可行。

或者,您可以探索:

  • 浮点数: 提供更广泛的范围,但精度有所下降。
  • 十进制数: 使用十进制(65,0) 列类型支持最多 65 位的整数值,提供范围和精度的平衡.

以上是如何处理超出 MySQL BIGINT 限制的大量整数:Varchar 与其他选项?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn