mongodb 分页查询

当数据库中数据较多,查询的数据量较大时,很容易给mongo数据库带来负担,为此,写了一个简单的分页查询算法,基于nodejs 的mongoose 模块:

注:依赖库:async

 

var findEach = function (model, condition, sort, key, views, cb) {

    //model.find(condition, views).sort(sort).lean().exec(function (err, docs) {
    //    cb(err, docs);
    //});


    var allCount = 0;
    var searchInterval = 2000;

    var returnData = [];
    async.auto({
        getCount: function (cb) {
            model.count(condition).lean().exec(function (err, count) {
                if (!err && count) {
                    allCount = count;
                }
                cb(err);
            })
        },
        processData: ["getCount", function (cb) {
            if (allCount) {
                if (allCount >= searchInterval) {
                    var arrLen = Math.floor(allCount / searchInterval);
                    var lastSearchCount = allCount % searchInterval;

                    var _tempArr = _.range(arrLen);
                    var searchIndex = 1;

                    var lastDataKey = null;
                    if (arrLen >= 1 && _tempArr.length) {
                        async.eachSeries(_tempArr, function (item, callback) {
                            if (searchIndex == 1) {
                                model.find(condition, views).limit(searchInterval).sort(sort).lean().exec(function (err, docs) {
                                    if (!err && docs.length) {
                                        lastDataKey = parseInt((docs[docs.length - 1])[key]);
                                        searchIndex++;
                                        returnData = returnData.concat(docs);
                                        callback(err);
                                    } else {
                                        callback(err);
                                    }
                                })
                            } else {
                                condition[key]["$gte"] = lastDataKey;

                                //console.log("condition",condition);
                                model.find(condition, views).limit(searchInterval).sort(sort).lean().exec(function (err, docs) {
                                    if (!err && docs.length) {
                                        lastDataKey = parseInt((docs[docs.length - 1])[key]);
                                        searchIndex++;
                                        returnData = returnData.concat(docs);

                                        callback(err);
                                    } else {
                                        callback(err);
                                    }
                                })

                            }
                        }, function (err, resp) {
                            if (!err) {
                                condition[key]["$gte"] = lastDataKey;
                                model.find(condition, views).limit(lastSearchCount).sort(sort).lean().exec(function (err, docs) {
                                    if (!err && docs.length) {
                                        returnData = returnData.concat(docs);
                                    }
                                    cb(err);
                                })
                            } else {
                                cb(err);
                            }
                        })
                    } else {
                        cb(null);
                    }
                } else {
                    model.find(condition, views).sort(sort).lean().exec(function (err, docs) {
                        if (!err && docs.length) {
                            returnData = docs;
                        }
                        cb(err);
                    })
                }
            } else {
                cb(null);
            }
        }]
    }, function (err, resp) {
        cb(err, returnData);
    });
}

例子:

var Mongoose = require('mongoose');
var Schema = Mongoose.Schema;
var async= require('async');

var AdminTable = {
    username: {type: String, default: ''},
    password: {type: String, default: ''},
    log_time: {type: Number, default: Date.now}
};

var SchemaOption = {};

var AdminSchema = new Mongoose.Schema(AdminTable, SchemaOption);

AdminSchema.statics.findAll= function (condition,views, cb) {
 findEach(this, condition, {"log_time": 1}, "log_time", views,  function (error, docs) {
	cb(error,docs);
}
}


 



 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值