使用pdo和关系数据库获取行

熊熊

我有一个小问题,我有一个包含2个表,用户和注释的数据库,我需要使用pdo打印结果。如果我尝试这段代码,一切都会很好:

$stmt = $dbConnection->prepare("SELECT comment_text, username FROM users, comments WHERE users.user_id = comments.user_id");
$stmt->execute();
$stmt->fetch(PDO::FETCH_ASSOC);

foreach ($stmt as $row) {
    echo $row['comment_text'] . "<br>By " . $row['username'] . "<br>";
}

但是如果我尝试添加一个获取结果的变量,我将得到完全不同的结果,只有2行,并且只有值的第一个字母...

$stmt = $dbConnection->prepare("SELECT comment_text, username FROM users, comments WHERE users.user_id = comments.user_id");
$stmt->execute();
$comment = $stmt->fetch(PDO::FETCH_ASSOC);

foreach ($comment as $row) {
    echo $row['comment_text'] . "<br>By " . $row['username'] . "<br>";
}
你的常识

如果我尝试这段代码,一切都会很好:

它不是。
这样,您将失去第一个评论。所以应该是

$stmt->execute();
foreach($stmt as $row )
{
    echo $row['comment_text']."<br>By ".$row['username']."<br>" ;
}

如果要将结果保存在数组中,则必须为此使用适当的函数

$stmt->execute();
$comments = $stmt->fetchAll(PDO::FETCH_ASSOC);
foreach($comments as $row )
{
    echo $row['comment_text']."<br>By ".$row['username']."<br>" ;
} 

虽然fetch()只获得一条记录,但fetchAll()的作用正如名字所示

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章