
本文介绍如何通过 sql 查询精准获取某条记录在表中的前驱 id(prev_id)与后继 id(next_id),适用于主键非连续、无序或存在删除间隙的场景,并提供安全、可集成的 php 实现方案。
在实际 Web 开发中(如文章翻页、相册浏览、日志导航等),常需根据当前记录 ID 快速定位“上一篇”和“下一篇”的 ID。由于数据库主键往往因删除、跳号或业务逻辑而不连续(例如当前 ID 是 50,前一条可能是 22,后一条是 81),直接使用 id-1 / id+1 的方式不可靠,必须依赖有序比较。
正确的思路是:
- 前一条 ID(prev_id):取所有 id
- 后一条 ID(next_id):取所有 id > 当前ID 中的最小值。
对应的标准 SQL 写法如下(以 articles 表、当前 ID 为 50 为例):
-- 获取前一条记录 ID SELECT MAX(id) AS prev_id FROM articles WHERE id < 50; -- 获取后一条记录 ID SELECT MIN(id) AS next_id FROM articles WHERE id > 50;
为提升性能,强烈建议在 id 字段上建立索引(通常主键已自动索引,无需额外操作)。若表中存在大量数据,该查询仍能保持 O(log n) 时间复杂度。
Wifi优化大师最新版是一款免费的手机应用程序,专为优化 Wi-Fi 体验而设计。它提供以下功能: 增强信号:提高 Wi-Fi 信号强度,防止网络中断。 加速 Wi-Fi:提升上网速度,带来更流畅的体验。 Wi-Fi 安检:检测同时在线设备,防止蹭网。 硬件加速:优化硬件传输性能,提升连接效率。 网速测试:实时监控网络速度,轻松获取网络状态。 Wifi优化大师还支持一键连接、密码记录和上网安全测试,为用户提供全面的 Wi-Fi 管理体验。
✅ 安全可靠的 PHP 封装示例(使用 PDO 防止 SQL 注入):
public function prevNext(int $id): array
{
$pdo = $this->getPdo(); // 假设已配置 PDO 实例
$stmt = $pdo->prepare("
SELECT
(SELECT MAX(id) FROM articles WHERE id < ?) AS prev_id,
(SELECT MIN(id) FROM articles WHERE id > ?) AS next_id
");
$stmt->execute([$id, $id]);
return $stmt->fetch(PDO::FETCH_ASSOC) ?: ['prev_id' => null, 'next_id' => null];
}⚠️ 注意事项:
- 若当前 ID 是表中最小值,则 prev_id 为 NULL;同理,最大值时 next_id 为 NULL;
- 不要拼接 $id 到 SQL 字符串中(原文中 $id 直接嵌入存在严重 SQL 注入风险);
- 单次查询同时获取两个值比执行两条独立查询更高效(减少网络往返与解析开销);
- 如需关联完整记录(如标题、URL),可在子查询基础上 JOIN 主表,但需注意 NULL 处理。
综上,利用 MAX(id) 与 MIN(id) 配合范围条件,是获取逻辑上下文 ID 的最简洁、高效且符合关系代数本质的方案。









