MySQL 导入错误整数:2147483647
当尝试将重要整数插入 MySQL 数据库时,用户可能会遇到一个特殊问题,即存储的数字与预期的数字不同。为了深入研究解决方案,让我们探索提供的代码片段:
$sql_query = "INSERT INTO users_info (steam64) VALUES ('$steam64')";
它尝试将变量 $steam64 中存储的值插入到名为 steam64 的数据库列中。然而,用户报告插入的值与 $steam64 中保存的值不同。此问题的根本原因在于 steam64 列的数据类型。在MySQL中,整数的默认数据类型是INT,它可以存储从-2,147,483,648到2,147,483,647的值。
在这种情况下,插入的值(2147483647)超出了一个可以容纳的最大值INT 数据类型。因此,MySQL 会自动将该值转换为它可以容纳的最大整数,即 2147483647。
要解决此问题,必须将 steam64 列的数据类型更改为 BIGINT。该数据类型支持的值范围更大,可以轻松容纳 2147483647 的值,而无需任何截断或转换。一旦修改数据类型,正确的值将被插入到数据库中。
以上是为什么 MySQL 存储的是 2147483647 而不是我的大整数值?的详细内容。更多信息请关注PHP中文网其他相关文章!