droos02800 2018-06-07 02:35
浏览 33
已采纳

从SQL表中获取以前的记录

I figure out how I can get the next adid using this:

$sql_next = "SELECT adid FROM table WHERE adid > $current_adid ORDER BY adid 
LIMIT 1";
if ($result = $mysqli->query($query)) {
while ($row = $result->fetch_assoc()) {

$next = $row['adid'];

echo '<a href="https://someurl.com/'.$next.'">Next</a>';

}
}

However, I am not sure how to get the previous adid. I tried changing WHERE adid < $current_adid but it didn't do the trick. What should I use to get a previous record from the SQL table?

  • 写回答

1条回答 默认 最新

  • duanchi8112 2018-06-07 02:40
    关注

    You need to reverse more than just the comparison:

    SELECT adid
    FROM table
    WHERE adid < $current_adid
    ORDER BY adid DESC
    LIMIT 1;
    

    The ORDER BY direction also needs to be reversed.

    You could also replace these with:

    SELECT MIN(adid)
    FROM table
    WHERE adid > $current_adid;
    
    SELECT MAX(adid)
    FROM table
    WHERE adid < $current_adid;
    

    The aggregation functions might make the logic clearer.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥30 BC260Y用MQTT向阿里云发布主题消息一直错误
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 Centos / PETGEM
  • ¥15 划分vlan后不通了
  • ¥20 用雷电模拟器安装百达屋apk一直闪退
  • ¥15 算能科技20240506咨询(拒绝大模型回答)