node.js - mongoose如何取得全部结果数量并只提取部分结果
PHPz
PHPz 2017-04-17 11:28:22
[Node.js讨论组]

如题,在跟着这个课程,写一个博客系统,不过我想把里面用mongodb写的部分改成mongoose的方法。取文章这里遇到了些问题, 原文是这样写的。

Post.getTen = function(name, page, callback) {
  //打开数据库
  mongodb.open(function (err, db) {
    if (err) {
      return callback(err);
    }
    //读取 posts 集合
    db.collection('posts', function (err, collection) {
      if (err) {
        mongodb.close();
        return callback(err);
      }
      var query = {};
      if (name) {
        query.name = name;
      }
      //使用 count 返回特定查询的文档数 total
      collection.count(query, function (err, total) {
        //根据 query 对象查询,并跳过前 (page-1)*10 个结果,返回之后的 10 个结果
        collection.find(query, {
          skip: (page - 1)*10,
          limit: 10
        }).sort({
          time: -1
        }).toArray(function (err, docs) {
          mongodb.close();
          if (err) {
            return callback(err);
          }
          //解析 markdown 为 html
          docs.forEach(function (doc) {
            doc.post = markdown.toHTML(doc.post);
          });  
          callback(null, docs, total);
        });
      });
    });
  });
};

获得总数是用来判断是否为最后一页的,但是我用mongoose写的话不知道该如何获取查询到查询结果的总数,写到这样不知道如何写了

Post.getFive = function(name,page,callback){
  var querystr = {};
  if(name){
    querystr.name = name;
  }

  var query = Post.find(querystr).skip((page-1)*5).limit(5);
  query.sort({time:-1});
  query.exec(function(err,results){
    if(err){
      console.log(err);
    }
    else{
      results.forEach(function (doc) {
            doc.post = markdown.toHTML(doc.post);
        });  

      console.log(total);
      callback(null, results, total);
    }
  })
}

求大神指点下。。。

PHPz
PHPz

学习是最好的投资!

全部回复(2)
PHP中文网

Mongoose 里面是使用 Model#count 来获得数量的。看起来你这里的 Post 应该就是个 model 吧,使用 Post.count 加上合适的条件就行了。

黄舟

刚好自学碰到,贴一下我写的code

router.get('/', function(req, res) {
  var page = req.query.p ? parseInt(req.query.p) : 1;
  Posts.count({}, function(err, count) {
    Posts.find({}, null, {skip: (page-1)*3, limit: 3}, function(err, posts) {
      res.render('index', {
        title: '主页',
        user: req.session.user,
        posts: posts,
        page: page,
        isFirstPage: page == 1,
        isLastPage: (page-1)*3 + posts.length == count,
        success: req.flash('success').toString(),
        error: req.flash('error').toString()
      });
    });
  });
});

其实官方文档上有类似的链接描述

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号