php - 如果最后一个查询有评论,我的查询将不起作用。
问题描述
我们一直在努力应对 PHP 中的某些情况,其中某些查询不起作用。我们发现只有在执行的最后一个查询中有注释时才会发生非工作查询。
在 php 中,我们有这样的东西:
$getUsersQuery = "SELECT * from `users` where active = 1; ##DEVELOPER: JOE";
$getUsersStmt = $con->prepare($getUsersQuery);
$getUsersStmt->execute();
$users = $getUsersStmt->fetchAll();
$getProductsQuery = "SELECT * from `products` where active = 1; ##DEVELOPER: JOE";
$getProductsStmt = $con->prepare($getProductsQuery);
$getProductsStmt->execute();
$products = $getProductsStmt->fetchAll();
对于$users
变量,它包含准确的数据,但在$products
变量中,它不包含任何内容。经过一段时间的配置,我们得到一个理论,这是因为执行的最后一个查询对其进行了评论##DEVELOPER: JOE
。我们删除了第一个查询的注释,第二个查询有效。我们已经对其进行了测试,并且该理论得到了证明。顺便说一句,我们使用的是 MySql 和 PHP 5。
我们现在知道它发生的原因。但我们的问题是,它为什么会发生?
如果您有想法,请发表评论。这对我们会有很大的帮助。谢谢。
解决方案
罪魁祸首不是评论本身。它是;
语句分隔符、注释和两个不同语句的组合。这是一个更简单的重现代码:
$stmt = $con->prepare('SELECT CURRENT_DATE; #');
$stmt->execute();
var_dump($stmt->fetchAll());
$stmt2 = $con->prepare('SELECT CURRENT_TIME');
$stmt2->execute();
var_dump($stmt2->fetchAll());
array(1) {
[0]=>
array(2) {
["CURRENT_DATE"]=>
string(10) "2018-11-13"
[0]=>
string(10) "2018-11-13"
}
}
array(0) {
}
可能发生的情况是 PDO 认为您正在发布多个语句,因此需要多个结果集。如果您覆盖该语句,它似乎会自动清除内容,但如果您创建一个新变量,它似乎仍然希望第一个语句完成。
如果您PDOStatement::nextRowset()
再次调用一切正常:
$stmt = $con->prepare('SELECT CURRENT_DATE; #');
$stmt->execute();
var_dump($stmt->fetchAll());
$stmt->nextRowset(); // <--- Retrieve the "phantom" result-set
$stmt2 = $con->prepare('SELECT CURRENT_TIME');
$stmt2->execute();
var_dump($stmt2->fetchAll());
或者,您可以设置PDO::ATTR_EMULATE_PREPARES => false
PDO 不会解析 SQL 并将作业交给 MySQL 服务器。
推荐阅读
- swift - URLSessionConfiguration 背景,超时问题,在 Postman 中工作正常
- python - Python 文档字符串中作为抽象类名的参数的类型是什么?
- python - Select 语句中的 Pace Maker 不起作用
- c++ - 为 I2C 正确格式化数据 (Wire.write)
- mysql - 为什么这个 DELETE 查询给我一个语法错误?
- node.js - 我怎样才能在loopback4中加入两个表
- push-notification - 我们可以增加谷歌控制台项目中的主题和订阅数量吗?
- jakarta-ee - JavaEE:注入 @Alteriative 到 Insance
没有默认实现 - ruby-on-rails - 如何使用 rolify gem 显示与用户关联的角色名称?
- angular - map() 中的拼接函数只删除数组的一半