我会尽量保持这个简单.我在MySQL数据库表上使用BIGINT数据类型.我有一个函数生成一个唯一的随机数,可以跨越12位到13位摘要长度.
当我使用12位数的数字插入数据库时,它输入就好了,
但是当我使用13位或更长的值时,它似乎是圆形或其他东西.这里是
$defaultText = 'some string'; //just some string
$web_id = 12;
$element_id = 23112182735363; //case 1 (doesn't work)
//$element_id = 2311218333205; //case 2, does work ()
mysql_query("INSERT INTO tableName (web_id, element_id, content)
VALUES ($web_id, $element_id, '".mysql_real_escape_string($defaultText)."')");
结果:
在第一种情况下,它会插入一个略有不同的数字,通常由于某种原因而舍入.
如果是两个,它插入数字就好了!也许有人可以帮助揭开这个神秘面纱!再次感谢!
big int数据类型:
bigint(200)
解决方法:
数字从PHP_INT_MAX开始失去精度.另见:http://www.php.net/manual/en/reserved.constants.php#constant.php-int-max
之后,它们变成了精度有限的浮子并导致奇怪的舍入问题.在PHP中支持BIGINT的唯一方法是使用字符串.