我有一个PHP脚本,通过MysqL_选择数据,但最近我一直在读PDO是要走的路,而且MysqL_正在变得折旧.现在我将该脚本转换为PDO.
我的问题是,我没有使用$_POST来选择.我只想选择包含所有数据的整个表,所以我输入以下查询:
$query = $dbh->prepare("SELECT * FROM students");
$query->execute();
$result = $query->fetchall(); // or you can just $result = $query as hakre proposed!
所以就像我使用旧的折旧MysqL_版本的脚本一样,我使用echo来回显一个带有数据的表.
echo
"<table border='2'>
<tr>
<th>ID</th>
<th>A Number</th>
<th>First Name</th>
<th>Last Name</th>
<th>Why</th>
<th>Comments</th>
<th>Signintime</th>
</tr>"
;
foreach($result as $row)
{
echo "<tr>";
echo "<td>" . $row['id'] . "</td>";
echo "<td><a href=Student.PHP?studentA_num=" . $row['anum'] . ">" .$row['anum'] . " </a></td>";
echo "<td>" . $row['first'] . "</td>";
echo "<td>" . $row['last'] . "</td>";
echo "<td>" . $row['why'] . "</td>";
echo "<td>" . $row['comments'] . "</td>";
echo "<td>" . $row['signintime'] . "</td>";
echo "<td> <input type=\"button\" value=\"Start Session\"onClick=\accept.PHP?id=" . $row['id'] . "&start=true></td>";
}
echo "</tr>";
echo "</table>";
现在使用这个,我无法获得单个输出到我的表.
我的问题是我在选择陈述中遗漏了什么?或者我没有取任何行?另外我在init.PHP所需的另一个名为connect.PHP的脚本中设置连接设置(在我的所有页面的顶部)
编辑:1
编辑代码,使它现在可以工作,还添加一张图片,以显示其他人应该看起来如何!希望有人可以将它用于某种用途!
解决方法:
你实际上做得太多了:
$query = $dbh->prepare("SELECT * FROM students");
$query->execute();
$result = $dbh->query($query);
问题在于:
$result = $dbh->query($query);
检查http://php.net/pdo.query,参数是一个字符串,实际上是上面已经使用的sql字符串,而不是PDO :: prepare()调用的结果值.
对于简单的查询,您可以这样做:
$result = $dbh->query("SELECT * FROM students");
或者如果你想准备:
$query = $dbh->prepare("SELECT * FROM students");
$query->execute();
$result = $query;
如果你想在查询中插入变量,那么后者是一些样板文件,这就是你准备它的原因.
下一个问题是foreach行:
foreach($result as $row);