1

嗨,我想知道您是否可以帮助我动态构建方法链,如果您知道如何,我怀疑这很容易做到……

使用 mongoose 和 node.js 我正在查询一个 mongo 数据库。我使用一个函数,我将一个对象传递给它,如下所示:

transaction = {
       model: a mongoose model
       req: Express.js request object
       res: Express.js response object
       query: a mongo db query eg, {_id:xxxxx}
       populate: [ {
         field: 'name_of_doc_field'
         select: 'field1,field2'
       } ]
    }

我正在动态构建查询,并且在函数中我不知道需要填充多少字段,或者是否需要偏移量或限制。

我想链接我的发现:

transaction.model.find(transaction.query).skip(offset).limit(limit).exec(function(err, collection_obj){...})

我如何动态构建这个链,我需要测试是否在测试对象中提供了偏移量,是否将 .skip 方法添加到链等,并且使用 populate 方法,将有一个项目数组,该数组中的每个项目都需要一个新的填充方法添加到链中。

最后,我需要一个 exec 方法到链的末尾。

提前感谢您的帮助

// Generated by CoffeeScript 1.4.0
    module.exports = {
      findMany: function(transaction) {
        var collection_obj, limit, offset;
        offset = parseInt(transaction.req.query.offset) || 0;
        limit = parseInt(transaction.req.query.limit) || 100;
        collection_obj = null;
        return transaction.model.find(transaction.query).skip(offset).limit(limit).exec(function(err, collection_obj) {
          return found(err, collection_obj, transaction.req, transaction.res);
        });
      },
    }
4

1 回答 1

2

您可以将链分解为可以根据以下内容有条件地执行的步骤transaction

var q = transaction.model.find(transaction.query);
if (offset) {
  q = q.skip(offset);
}
if (limit) {
  q = q.limit(limit);
}
if (transaction.populate) {
  transaction.populate.forEach(function(pop) {
     q = q.populate(pop.field, pop.select);
  });
}
q.exec(function(err, collection_obj){...});
于 2013-02-19T13:22:38.493 回答