【问题标题】:Selecting table data with PDO statements [duplicate]使用 PDO 语句选择表数据
【发布时间】:2012-12-15 18:43:16
【问题描述】:

我有一个通过 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>";

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

我的问题是我的选择语句中是否缺少某些内容?还是我没有获取任何行?我还在另一个名为 connect.php 的脚本中设置了连接设置,这是 init.php 所需的(在我所有页面的顶部)

编辑:1

编辑了代码,使其现在可以工作,还添加了一张图片来向其他人展示它的外观!希望有人可以将其用于某种用途!

【问题讨论】:

    标签: php mysql select pdo


    【解决方案1】:

    你的代码错了:

    $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 后的分号后,其余代码将正常工作。

    【讨论】:

      【解决方案2】:

      其实你做的太多了:

      $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 循环的主体。

      【讨论】:

      • 我犯了一个如此愚蠢的错误!谢谢你们俩!
      • 你是新人。万一遇到问题,从上到下开始验证。您可以使用 var_dump() 查看变量,这通常很有帮助。还将开发的错误报告设置为开启并设置为最高级别。
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-07-31
      • 2017-07-02
      相关资源
      最近更新 更多