- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我们一直在努力解决 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 服务器。
关于php - 如果最后一个查询有评论,我的查询就不起作用。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53280929/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!