网站首页 > 技术文章 正文
有时候我们页面要实现显示:上一篇下一篇的功能,但是我们的文章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查询机制)
- 最近发表
- 标签列表
-
- 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 (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)