最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
MongoDB 随机查询一条数据语语句
时间:2022-06-29 10:38:18 编辑:袖梨 来源:一聚教程网
换个思路,我们可以在每个文档加一个随机键(random),用Math.random()方法生成随机数,存放进文档里。查询的时候,同样用Math.random()生成一个随机数,返回一条集合中随机数小于这个随机数的文档。当然,也有可能没有小于这个随机数的文档,但如果这样,就必定有一个大于等于这个随机数的文档,除非集合是空的。
查询一条随机数据
| 代码如下 | 复制代码 |
|
var random=Math.random(); 或 PRIMARY> db.phoneMessage.count() |
|
查询多条随机数据
1.参考单条查询,可用个循环,将查询的数据插入到集合t中。
| 代码如下 | 复制代码 |
|
for(var i=0;i<1000;i++) {var c=db.phoneMessage.find().limit(-1).skip(Math.floor(Math.random()*8704221)).next(); db.t.insert(c) } |
|
这种方法简单,但是数据量大的情况下,skip效率很低,耗时较长。
2.通过map/reduce来查询
mongodb 2.2以上可用如下方法,2.0格式有点问题
| 代码如下 | 复制代码 |
|
function mapf() { function reducef(key,values) { |
|
此方法也无法应对大数据量情况,会报错InternalError: too much recursion
3.添加一个随机数的字段,再查询就简单了
这种方法会比较好,但更改了集合结构。
相关文章
- 整理拾光全部隐藏物品获取方法攻略 12-04
- 魔理沙还书姬虫百百世彩蛋位置一览 12-04
- 阿西美女室友竟然2第六章全流程攻略 12-04
- 超英派遣中心第四章第一轮班派遣攻略 12-04
- 阿西美女室友竟然2第五章全流程攻略 12-04
- 梦之形跳跳锤维斯珀玩法攻略分享 12-04