我有一个用户填充的模型。所以我想查找其中一个用户= someString。
所以使用Waterline我可以做到这一点
Partie.find().populate('users').where({category:{'contains':'sport'}}).exec(function(e,r){
console.log(r);
res.json(200,r);
});
但是如何在'用户'?这是一个数组。
"users": [
{
"username": "firstUser",
"createdAt": "2015-07-30T15:33:57.662Z",
"updatedAt": "2015-07-30T15:33:57.662Z",
"id": "55ba43e58cce9ee80865271b"
},
{
"username": "someUsername",
"createdAt": "2015-08-04T12:14:50.291Z",
"updatedAt": "2015-08-04T12:14:50.291Z",
"id": "55c0acba2d1502ed2faf2b3b"
}
],...
不确定这是否可行。随意提出替代方案
答案 0 :(得分:3)
您可以将第二个参数传递给使用包含查询条件的填充,例如:
Partie.find().populate('users', {where: {username: "someUsername"}})...
根据我的经验(使用最新的水线),上面的示例仅填充与给定用户名匹配的用户到Partie对象中。
但是,在我的机器上,它并不限制从搜索查询返回的“派对”(这可能与我的水线/ postgres适配器版本有关)。我通过在返回之后过滤完整数组来解决了这个问题(使用lodash):
res.json(_.filter(parties, function(party){
// Pluck all usernames and check if 'someUserName' is attending this party
return _.contains(_.pluck(party.users, 'username'), 'someUserName');
}));
请注意,对于大型数据集,使用上述示例的过滤器是不可取的!