我对PDO有点问题。大约2分钟前,我发布了另一个问题,答案很快,但现在我又犯了一个错误。
这是代码:
$hostname='localhost';
$username='Elmad2';
$password='*******';
try {
$dbh = new PDO("mysql:host=$hostname;dbname=portals",$username,$password);
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dbh->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$stmt = $dbh->prepare('SELECT * FROM docenten');
$stmt->setFetchMode(PDO::FETCH_ASSOC);
$stmt->execute();
$Result = $stmt->fetchAll();
第81行>>如果($dbh->查询($stmt)){
foreach ($Result as $row) {
echo '<div class="item"><a href="teachers/item.php?id=' . $row[id] . '">
<h1 class="title">' . $row[title]. '</h1></a>
<h3 class="author">Geplaatst door: ' . $row[info_bys] . '</h3><span class="description">' . $row[info_shorts] . '</span><br><img src="../' . $row[filepath] . '" class="item-image"><br>
<a href="teachers/item.php?id='.$row[id].'"><button type="button" class="read_more btn btn-primary">Lees meer</button></a>
</div>';
}
}
else{
echo 'error';
}
$dbh = null;
}
catch(PDOException $e)
{
echo $e->getMessage();
}
这是一个错误:
警告:PDO::query()要求参数1为字符串,对象在第81行的>/home/ubuntu/workspace/portals/teachers.php中给出
我希望有人能帮助我,
谢谢。
您不需要调用PDO::query()
。对于准备好的语句,您可以调用PDO::prepare()
,然后PDOStatement::execute()
执行查询,您可以使用PDOStatement::fetch*
检索结果。
PDO::query()
仅用于动态SQL;它以字符串SQL查询语句作为参数,例如SELECT
语句,&c.
@rizier123回答了我的问题。
我只需要删除if语句并在行数据中添加引号。
感谢@rizier123