我在PDO语句后有一个while循环。我的代码如下。
$query = "SELECT * FROM private_messages WHERE to_id = :my_id AND to_email = :email AND recipient_delete='0' ORDER BY time_sent DESC";
$stmt = $dbo->prepare($query);
$stmt->execute(array(":my_id" => $my_id, ":email" => $email));
$row = $stmt->fetch();
while($row = $stmt->fetch()){ ...
输出的结果总是缺少其中一行,因此用户收到的最新私人消息永远不会显示。我有一个通知器,它告诉用户他们有多少新消息,这些消息正确计数(它表明他们有比实际消息列表输出多一个消息)。我无法使用谷歌找到答案,这让我发疯。这是我80年代早期BASIC早期以来第一次尝试使用任何语言进行编程,因此我花了所有时间阅读有关事情的内容,但找不到任何可以帮助我解决这个问题。谁能告诉我哪里出错了?谢谢!
答案 0 :(得分:5)
删除该行:
$row = $stmt->fetch();
它将第一行放在$row
然后当你这样做:
while($row = $stmt->fetch()){ ...
它从第二行开始提取,你获取的第一行丢失,这就是你总是只丢失一行的原因。