TODO:数据库优化之分页
来源:互联网 发布:取消软件定位系统 编辑:程序博客网 时间:2024/06/10 03:40
TODO:数据库优化之分页
本文的例子是以MongoDB数据库为准,其它数据库各位也可以举一反三进行优化。
在MongoDB中分页使用
a.skip(n)跳过前n个匹配的文档;
b.limit(m)返回m个结果,要是匹配的结果不到m个,则返回匹配数据量的结果,m是指定上限数量,而不是下限数量;
c.sort({“name”: 1,”address”:-1}),1表示升序,-1表示降序。
使用skip跳过少量的文档还可以。但是数据量非常多的话,skip就会变得非常慢,每个数据库都会有这种情况,所以要尽量避免过多的使用skip。那要怎么做分页,我们可以利用上次的结果来计算下次的查询。
1.使用skip的分页
Page1 = db.user.find({}).limit(100)
Page2 = db.user.find({}).skip(100).limit(100)
Page3 = db.user.find({}).skip(200).limit(100)
2.利用上次的结果来计算下次的查询,按时间戳(timestamp)排序
获取第一页
Page1 = db.user.find({}).sort({“timestamp”: -1}).limit(10)
获取当前页面的最后一条记录的时间戳lasttimestamp,
根据lasttimestamp进行查询下一页数据
Nextpage=db.user.find({“timestamp”:{“$gt”:lasttimestamp}}).sort({“timestamp”: -1}).limit(10)
这样查询就没有使用到skip,但是要确保timestamp唯一约束确保文档中的数据没有相同的值。
wxgzh:ludong86
- TODO:数据库优化之分页
- MySql之分页优化
- MYSQL优化之分页
- MySQL 查询之分页优化
- [todo]scala之spray
- 数据库查询优化及分页算法
- 海量数据库查询优化几分页算法
- 数据库查询的分页优化技巧
- 数据库 分页优化的四种方式
- Oracle数据库分页查询语句与优化
- 性能优化之数据库优化
- 性能优化之数据库优化
- 性能优化之数据库优化
- 性能优化之数据库优化
- 性能优化之数据库优化
- 性能优化之数据库优化
- 性能优化之数据库优化
- 性能优化之数据库优化
- 巧用空值判断函数nvl()
- 输出国际键盘
- 模拟退火算法
- Java的transient关键字
- HTML&CSS之边界合并和边界溢出
- TODO:数据库优化之分页
- QT—base20161123
- CentOS6.7下使用cmake编译安装MySQL5.5.32
- 平方根法求解线性方程组(C++实现)
- 学习是需要不断巩固的
- 《C陷阱与缺陷》学习笔记(上)
- 无向图邻接矩阵的储存和深度优先遍历
- dasdasd
- CodeForces 138D