网站首页 > 技术文章 正文
有时候我们页面要实现显示:上一篇下一篇的功能,但是我们的文章ID却不是1,2,3,4…的模式编下去的,而是会跳跃
只会保证大小顺序,那么怎么办呢,这里提供两种思路:
1、给定一个字段保存序号
我们可新增一个字段来保存文章的序号,这样子我们就可以直接按以前的习惯来读取上一篇下一篇,建立索引
后效率会很高,但是这种方法的弊端就是维护起来比较麻烦,要确保这个序号不冲突,这个其实就相当于主键了,
如果要追求查询效率的话可以用这种方法。
2、获取最靠近该id的两条记录
如下sql,我们用max函数和min函数就可实现,只不过效率没有第一种方式高,我们页面显示的时候需要异步查询,或者说放入redis缓存也可的。
- select id,title as title,1 as type from topic where id = (select max(id) from topic where id <701085131963629568 and menuid=697853733811257344)
 - UNION
 - select id,title as title,2 as type from topic where id = (select min(id) from topic where id >701085131963629568 and menuid=697853733811257344)
 
猜你喜欢
- 2024-10-27 MySQL左查询最全介绍(sql 左查询)
 - 2024-10-27 mysql查询指定父级下所有子级(mysql根据子节点查父)
 - 2024-10-27 MySQL数据库入门(七)多表查询及大量练习
 - 2024-10-27 mysql进行数据查询(单表查询)(mysql 查询数据表)
 - 2024-10-27 【执行计划】MySQL如何执行查询?(mysql执行查询语句)
 - 2024-10-27 MySQL查询列必须和group by字段一致吗?
 - 2024-10-27 查看MySQL所有数据库列表(mysql怎么查看数据库列表)
 - 2024-10-27 「mysql」mysql调优时必须掌握的慢查询语句排查命令
 - 2024-10-27 有一张1000W 数据记录的表,主键id自增,如何随机抽取10条记录?
 - 2024-10-27 MySQL进阶实战7,查询的执行过程(mysql查询机制)
 
- 最近发表
 - 
- 聊一下 gRPC 的 C++ 异步编程_grpc 异步流模式
 - [原创首发]安全日志管理中心实战(3)——开源NIDS之suricata部署
 - 超详细手把手搭建在ubuntu系统的FFmpeg环境
 - Nginx运维之路(Docker多段构建新版本并增加第三方模
 - 92.1K小星星,一款开源免费的远程桌面,让你告别付费远程控制!
 - Go 人脸识别教程_piwigo人脸识别
 - 安卓手机安装Termux——搭建移动服务器
 - ubuntu 安装开发环境(c/c++ 15)_ubuntu安装c++编译器
 - Rust开发环境搭建指南:从安装到镜像配置的零坑实践
 - Windows系统安装VirtualBox构造本地Linux开发环境
 
 
- 标签列表
 - 
- cmd/c (90)
 - c++中::是什么意思 (84)
 - 标签用于 (71)
 - 主键只能有一个吗 (77)
 - c#console.writeline不显示 (95)
 - pythoncase语句 (88)
 - es6includes (74)
 - sqlset (76)
 - apt-getinstall-y (100)
 - node_modules怎么生成 (87)
 - chromepost (71)
 - flexdirection (73)
 - c++int转char (80)
 - mysqlany_value (79)
 - static函数和普通函数 (84)
 - el-date-picker开始日期早于结束日期 (76)
 - js判断是否是json字符串 (75)
 - c语言min函数头文件 (77)
 - asynccallback (87)
 - localstorage.removeitem (77)
 - vector线程安全吗 (73)
 - java (73)
 - js数组插入 (83)
 - mac安装java (72)
 - 无效的列索引 (74)
 
 
