php – BIGINT在MySQL中更改我的号码?为什么这样做?

我会尽量保持这个简单.我在MySQL数据库表上使用BIGINT数据类型.我有一个函数生成一个唯一的随机数,可以跨越12位到13位摘要长度.

当我使用12位数的数字插入数据库时​​,它输入就好了,

但是当我使用13位或更长的值时,它似乎是圆形或其他东西.这里是

PHP

$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的唯一方法是使用字符串.

上一篇:如何在php中使用bigint来防止sql注入?


下一篇:mysql中int、bigint、smallint、tinyint 长度