duandeng2011
2014-11-14 11:08
浏览 306
已采纳

php中的PDO STRINGIFY_FETCHES和浮点值[重复]

This question already has an answer here:

I am trying to fetch the correct datatype from mysql with PDO on php. I have a Problem with float values. Even if the column in table is set to FLOAT(10,2), PDO isnt giving me back the correct number of decimals. Is this a PDO bug? I am using Apache/2.4.4 (Win32) OpenSSL/0.9.8y PHP/5.4.16 and mysqlnd 5.0.10. Is there any way to get back the correct result which is not something like round($var, 2)?

$sDbHost = 'someip';
$sDbUser = 'root';
$sDbPass = '';

$oPdo = new PDO("mysql:host={$sDbHost}", $sDbUser, $sDbPass);
$oPdoConn = $oPdo;
// make PDO use the datatype being returned from mysql
$oPdoConn->setAttribute(PDO::ATTR_STRINGIFY_FETCHES, false);
$oPdoConn->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);

// create a table with a float of lenght 10 and TWO(!) decimalplaces
$oPdoConn->query("CREATE TABLE IF NOT EXISTS `paymentClass`.`floatTestTable3` (`testfield` float(10,2) NOT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8;");
$oPdoConn->query("INSERT INTO `paymentClass`.`floatTestTable3` VALUES (10.99);");

$oPdoFloatTest = $oPdoConn->query("SELECT * FROM `paymentClass`.`floatTestTable3`");

var_dump($oPdoFloatTest->fetchAll());

// result should be float 10.99

// but result is float 10.989999771118

</div>

图片转代码服务由CSDN问答提供 功能建议

此问题已经存在 这里有一个答案:

  • PHP PDO查询返回FLOAT字段的不准确值 2 answers

    我正在尝试使用PDO从mysql获取正确的数据类型 PHP。 我有浮点值的问题。 即使表中的列设置为FLOAT(10,2),PDO也不会给我正确的小数位数。 这是一个PDO错误吗? 我使用Apache / 2.4.4(Win32)OpenSSL / 0.9.8y PHP / 5.4.16和mysqlnd 5.0.10。 有没有办法找回不正确的结果($ var,2)?

      $ sDbHost ='someip'; 
     $ sDbUser ='  root'; 
     $ sDbPass =''; 
     
     $ oPdo = new PDO(“mysql:host = {$ sDbHost}”,$ sDbUser,$ sDbPass); 
     $ oPdoConn = $ oPdo; 
     /  / make PDO使用从mysql返回的数据类型
     $ oPdoConn-&gt; setAttribute(PDO :: ATTR_STRINGIFY_FETCHES,false); 
     $ oPdoConn-&gt; setAttribute(PDO :: ATTR_EMULATE_PREPARES,false); 
     
     // 创建一个浮动长度为10和两个(!)十进制
     $ oPdoConn-&gt;查询的表(“CREATE TABLE IF NOT EXISTS`supportClass``floatTestTable3`(`testfield`flove(10,2)NOT NULL)  ENGINE = InnoDB DEFAULT CHARSET = utf8;“); 
     $ oPdoConn-&gt; query(”INSERT INTO`paymentClass``floatTestTable3` VALUES(10.99);“); 
     
     $ oPdoFloatTest = $ oPdoConn-&gt;  query(“SELECT * FROM`inloadClass` .floatTestTable3`”); 
     
    var_dump($ oPdoFloatTest-&gt; fetchAll()); 
       
     
     

    //结果应为float 10.99

    //但结果为float 10.9899 99771118

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • doumu1951 2014-12-09 15:46
    已采纳

    Same problem as PHP PDO query returns inaccurate value for FLOAT fields

    The next time i will use DECIMAL instead of FLOAT.

    点赞 打赏 评论

相关推荐 更多相似问题