PHP 查询通常将所有列返回为字符串,即使在处理整数时也是如此或 MySQL 中的数值。当处理具有特定格式要求的数据时,例如多个服务使用的 JSON 输出,这可能会出现问题。
虽然一些消息来源声称不可能返回数字类型,但这是不完全正确。可以消除以下误解:
解决此问题的关键是使用 PHP 的 mysqlnd 驱动程序。与本机驱动程序不同,mysqlnd 支持返回整数(INTEGER、INT、SMALLINT、TINYINT、MEDIUMINT、BIGINT)和双精度浮点(DOUBLE)列的数字类型。
要验证您是否使用 mysqlnd,请运行 php -i。如果 pdo_mysql 部分提到“mysqlnd”,则表明驱动程序存在。否则,请按照以下步骤安装它:
Ubuntu:
确认存在:安装后,php -i 现在应该在 pdo_mysql 部分显示 mysqlnd 版本。
此外,请确保设置以下 PDO 设置正确:
通过 mysqlnd 和正确的 PDO 设置,您现在可以查询 MySQL 表并获取预期的数值格式:
$result = $pdo->query('SELECT * FROM table'); $row = $result->fetch(PDO::FETCH_OBJ); echo $row->integer_col; // 1 (integer) echo $row->double_col; // 1.55 (float) echo $row->decimal_col; // '1.20' (string)
以上是如何确保 MySQL 数字和整数列在 PHP 中作为正确的数据类型返回?的详细内容。更多信息请关注PHP中文网其他相关文章!