如何在 MySQL 中高效获取指定记录的上一条和下一条记录 ID

如何在 MySQL 中高效获取指定记录的上一条和下一条记录 ID

本文介绍如何通过 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优化大师app v1.0.1 安卓版

wifi优化大师app v1.0.1 安卓版

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 的最简洁、高效且符合关系代数本质的方案。

https://www.php.cn/faq/1965655.html

发表回复

Your email address will not be published. Required fields are marked *