如何使用 PHP 从 MySQL 正确检索整数和数字数据类型?
如何使用 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中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器)

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么?
