我提出了一个与此相关的问题,但我对使用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' }}
时,我得到了所有用户及其图像,但我没有得到图像架构,我得到了整个用户架构。
所以,我想要的是获取我所关注的用户的所有图像,按日期排序。这有什么解决方案吗?
谢谢你的进步!
答案 0 :(得分:4)
原因是您将_id
字段作为字符串而不是ObjectID
传递。试试这个:
var ObjectID = require("mongodb").ObjectID;
// ...
model.aggregate([
{$match: { _id : ObjectID('50f5c7265838530000000006') }},
// ...