[英]How do I perform a query in Mongoose?
> db.users.findOne();
{
"_id" : ObjectId("4db8ebb4c693ec0363000001"),
"fb" : {
"name" : {
"last" : "Sss",
"first" : "Fss",
"full" : "Fss"
},
"updatedTime" : "2011-04-27T09:51:01+0000",
"verified" : true,
"locale" : "en_US",
"timezone" : "-7",
"email" : "abc@gmail.com",
"gender" : "male",
"alias" : "abc",
"id" : "17447214"
}
}
這就是我的 Mongo object。 現在我想通過 ZCCADDEDB567ABAE643E15DCF0974E503Z 找到它:
User.findOne( { gender: "male" }, function(err, docs){
console.log(err); //returns Null
console.log(docs); //returns Null.
});
這不起作用:這也不起作用:
User.findOne( { fb: {gender:"male"} }, function...
Null,null。
這是我的全部內容:
app.get('/:uid',function(req,res){
params = {}
User.findOne({ $where : "this.fb.gender == 'male' " }, function(err, docs){
console.log(docs);
});
res.render('user', { locals:params });
});
我是 mongoose 的作者之一。 您可以通過以下幾種方式之一執行此查詢:
find
語法
User.findOne({'fb.gender': 'male'}, callback);
where
語法
User.where('fb.gender', 'male').findOne(callback);
命名為 scope 語法
UserSchema.namedscope('male').where('fb.gender', 'male'); //... var User = mongoose.model('User', UserSchema); // Now you can write queries even more succinctly and idiomatically User.male.findOne(callback);
嘗試這個:
User.findOne( { $where : "this.fb.gender == 'male' " } )
或者
User.findOne( { fb.gender : "male" } )
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.