带有mongoose和数组的聚合框架

时间:2013-01-16 22:05:50

标签: node.js mongodb express mongoose

我提出了一个与此相关的问题,但我对使用mongoose的聚合框架产生了新的疑问。例如,我有这个架构:

var userschema = new mongoose.Schema({

   user: String,
   pass: String,
   following: [String],
   imagen: [{ 

              title: String,
              date: { type: Date, default: Date.now },
              name: String,
              author: String,

           }],


});

这是聚合框架的代码:

app.get('/home', middleware.yeses, function (req, res){

 usermodel.findOne({ user: req.session.user }, function (err, user){

 model.aggregate([

       {$match: { _id : '50f5c7265838530000000006' }},
       {$unwind: '$imagen'},          
       {$sort: {'imagen.date': 1}}

    ], function (err, imagenes){

        if (err) throw err;

        console.log(imagenes);

        res.send('foo');

    });
   });
  });

我正在尝试进入所有images的控制台,只是像这样的imagen架构:

{  title: 'footitle',
   name: 'foophoto.png',
   date: Tue Jan 1 2013 22:32:12 GMT+0100 (CET),
   author: 'foouser'  }

获取按日期排序的所有imagen模式。

用户架构中的以下数组包含实际用户关注的用户_id。因此,使用{$match: { _id : '50f5c7265838530000000006' }},,我只获得了我正在关注的用户的图像。问题是,当执行此代码时,我收到此[],我得到的图像数组为空,因此代码不起作用,因为我关注的用户上传了照片。

当我删除这个{$match: { _id : '50f5c7265838530000000006' }}时,我得到了所有用户及其图像,但我没有得到图像架构,我得到了整个用户架构。

所以,我想要的是获取我所关注的用户的所有图像,按日期排序。这有什么解决方案吗?

谢谢你的进步!

1 个答案:

答案 0 :(得分:4)

原因是您将_id字段作为字符串而不是ObjectID传递。试试这个:

var ObjectID = require("mongodb").ObjectID;

// ...

model.aggregate([

  {$match: { _id : ObjectID('50f5c7265838530000000006') }},

  // ...