我有一列类型integer
长度为 10:
`some_number` int(10) unsigned NOT NULL
我在此列中插入了一个太长的数字:
$some_number = 715988985123857;
$query = "INSERT INTO this_table SET some_number = ?";
$stmt = $mysqli->prepare($query);
$stmt->bind_param('i', $some_number);
$stmt->execute();
当我查看表中的内容时,现在的数字是:
2147483647
如何以及为何715988985123857
变成2147483647
?
为什么没有被截断?
这种转变背后的机制是什么?可以用某种公式计算得到的数字吗?
我不是在寻找解决方案。我只是想了解一下具体数字。
http://dev.mysql.com/doc/refman/5.0/en/integer-types.html http://dev.mysql.com/doc/refman/5.0/en/integer-types.html
整数溢出会将数据库中允许的最大数量设置为
2147483647
所以你需要bigint
用于存储更大整数的数据类型
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)