PHP   发布时间:2022-04-05  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了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.我们删除了第一个查询的注释,第二个查询成功了.我们已经对其进行了测试,并且该理论得到了证明.顺便说一句,我们正在使用MysqLPHP 5.

如果您有想法,请注释掉.这将对我们有很大帮助.谢谢.

解决方法:

罪魁祸首不是评论本身.它是具有;的组合语句定界符,注释和两个不同的语句.这是一个更简单的复制@L_801_23@:

$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服务器.

大佬总结

以上是大佬教程为你收集整理的php-如果最后一个查询有评论,我的查询将不起作用.全部内容,希望文章能够帮你解决php-如果最后一个查询有评论,我的查询将不起作用.所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: