我们一直在努力解决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.
We now know the reason how it occurs. But our question is that, why is
it occurring?
如果您有想法,请注释掉.这将对我们有很大帮助.谢谢.
解决方法:
罪魁祸首不是评论本身.它是具有;的组合语句定界符,注释和两个不同的语句.这是一个更简单的复制代码:
$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服务器.
标签:mysql,php,pdo 来源: https://codeday.me/bug/20191024/1924245.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。