使用PDO语句选择表数据

时间:2012-12-31 17:31:19

标签: php mysql select pdo

我有一个通过mysql_选择数据的PHP脚本,但是最近我一直在阅读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>";

现在使用这个,我无法获得单个输出到我的表。

This is all that is being outputted

我的问题是我在选择陈述中遗漏了什么?或者我没有取任何行?另外我在另一个名为connect.php的脚本中设置的连接设置是init.php所需的(在我的所有页面的顶部)

编辑:1

编辑代码以便它现在可以正常工作,还添加了一张图片来向其他人展示它应该如何显示!希望有人可以将它用于某种用途! This is how it looks!

2 个答案:

答案 0 :(得分:11)

你实际上做得太多了:

$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);

由于末尾带有分号;,您将立即终止循环。删除该分号,以便以下角度括号的代码块成为foreach循环的主体。

答案 1 :(得分:6)

你的代码错了:

$query = $dbh->prepare("SELECT * FROM students");
$query->execute();
$result = $dbh->query($query);

执行准备好的声明后,您只需在其上调用fetchAll()

$query = $dbh->prepare("SELECT * FROM students");
$query->execute();
$result = $query->fetchAll();

在foreach之后删除分号后,其余代码将正常工作。