解决 PHP 从 MySQL 返回整数和数值的差异
使用 PHP 从 MySQL 检索数据时,可能会遇到以下问题:遇到类型不一致,其中整数和数字列作为字符串而不是其预期数据返回类型。
驱动程序问题
确定用于数据库连接的底层驱动程序至关重要。该问题通常源于使用本机 MySQL 驱动程序,该驱动程序缺乏将数字类型作为整数返回的能力。
识别 MySQLnd 驱动程序
确定您是否使用本机 MySQL 驱动程序检查 php -i 的输出。如果 pdo_mysql 部分中没有提及“mysqlnd”,则您可能使用的是本机驱动程序。
切换到 MySQLnd 驱动程序
解决方案在于切换到 mysqlnd 驱动程序,它支持正确返回数字类型。在 Ubuntu 上,可以通过以下方式实现:
sudo apt-get remove php5-mysql sudo apt-get install php5-mysqlnd sudo service apache2 restart
PDO 设置
安装 mysqlnd 驱动程序后,请确保正确设置以下 PDO 设置:
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); $pdo->setAttribute(PDO::ATTR_STRINGIFY_FETCHES, false);
已返回值
执行上述步骤后,MySQL 查询结果将按预期返回数字类型:
返回值的示例如下:
object(stdClass)[915] public 'integer_col' => int 1 public 'double_col' => float 1.55 public 'float_col' => float 1.5 public 'decimal_col' => string '1.20' (length=4) public 'bigint_col' => string '18446744073709551615' (length=20)
以上是为什么我的 MySQL 数值在 PHP 中以字符串形式返回,我该如何修复它?的详细内容。更多信息请关注PHP中文网其他相关文章!