【发布时间】:2015-05-28 19:32:30
【问题描述】:
这是在 phpMyAdmin 中运行的查询:
SELECT app . *
FROM `tap_applications` app, `tap_jobs` job
WHERE job.id = app.job_id
AND job.closed =0
AND job.user_id =1
这会返回五行 (Showing rows 0 - 4 ( 5 total, Query took 0.0008 sec)),我可以看到这些行是正确的。
这是我执行查询的 PHP 代码:
$id=1;
$stmt = $dbh->prepare('SELECT app.*
FROM `tap_applications` app, `tap_jobs` job
WHERE job.id = app.job_id
AND job.closed = 0
AND job.user_id=?');
if($stmt->execute(array($id))){
$apps = $stmt->fetch(PDO::FETCH_ASSOC);
echo '<pre>'; print_r($apps); exit();
}
这个输出:
Array
(
[id] => 2
[job_id] => 6
[name1] => Ben
[name2] => //redacted
[tel] => //redacted
[email] => //redacted
[cv] => 6-Ben1424692150.pdf
[seen] => 0
[time] => 2015-02-23 11:57:33
[decision] => 1
)
为什么没有输出 SQL 查询返回的所有行?
【问题讨论】:
-
php.net/manual/en/pdostatement.fetch.php : PDOStatement::fetch — 从结果集中获取下一行。
-
尝试使用fetchAll函数。
标签: php mysql sql phpmyadmin