如何使用 PHP 从 MySQL 正确检索整数和数字数据类型
使用 PHP 查询 MySQL 数据库时,确保以下内容至关重要:整数和数字数据类型按原样返回,而不是作为字符串返回。这对于数据完整性和与其他服务的兼容性至关重要。
不幸的是,默认情况下,PHP-MySQL 本机驱动程序将所有查询结果转换为字符串。这个问题一直是很多争论的主题,一些人声称这是一个实施限制,另一些人则认为这是不正确的。不过,要考虑的关键因素是所使用的驱动。
解决方案:使用 MySQLnd 驱动
要解决此问题,需要从原生切换MySQL 驱动程序到 mysqlnd 驱动程序。 mysqlnd 驱动程序支持正确返回整数和数字类型。
如何安装和检查 mysqlnd
在 Ubuntu 上,您可以使用以下命令安装 mysqlnd 驱动程序:
sudo apt-get remove php5-mysql sudo apt-get install php5-mysqlnd sudo service apache2 restart
要验证是否正在使用 mysqlnd,请检查 php -i 的输出。 pdo_mysql 部分现在应包含对 mysqlnd 的引用。
PDO 设置
此外,请确保正确配置以下 PDO 设置:
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); $pdo->setAttribute(PDO::ATTR_STRINGIFY_FETCHES, false);
返回值
使用 mysqlnd 驱动程序并应用适当的 PDO 设置后,将根据以下规则返回查询结果:
示例
以下示例说明了整数和数值数据的正确行为检索:
$pdo = new PDO(...); $stmt = $pdo->prepare('SELECT * FROM table'); $stmt->execute(); $result = $stmt->fetch(PDO::FETCH_OBJ); var_dump($result);
这将输出具有以下属性的对象:
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)
以上是如何使用 PHP 从 MySQL 正确检索整数和数字数据类型?的详细内容。更多信息请关注PHP中文网其他相关文章!