首页 >数据库 >mysql教程 >如何使用 PHP 从 MySQL 正确检索整数和数字数据类型?

如何使用 PHP 从 MySQL 正确检索整数和数字数据类型?

Patricia Arquette
Patricia Arquette原创
2024-12-08 21:02:14805浏览

How to Properly Retrieve Integer and Numeric Data Types from MySQL Using PHP?

如何使用 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 设置后,将根据以下规则返回查询结果:

  • 浮点类型 ( FLOAT、DOUBLE)将作为 PHP 浮点数返回。
  • 整数类型(INTEGER、INT、SMALLINT、 TINYINT、MEDIUMINT、BIGINT)将返回为 PHP 整数。
  • 定点类型(DECIMAL、NUMERIC)将返回为 PHP 字符串。

示例

以下示例说明了整数和数值数据的正确行为检索:

$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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn