题
假设我有一个 BlogPost
零到多嵌入的模型 Comment
文件。我可以查询并让 MongoDB 返回吗 仅有的 Comment
与我的查询规范匹配的对象?
例如, db.blog_posts.find({"comment.submitter": "some_name"})
仅返回评论列表。
编辑:一个例子:
import pymongo
connection = pymongo.Connection()
db = connection['dvds']
db['dvds'].insert({'title': "The Hitchhikers Guide to the Galaxy",
'episodes': [{'title': "Episode 1", 'desc': "..."},
{'title': "Episode 2", 'desc': "..."},
{'title': "Episode 3", 'desc': "..."},
{'title': "Episode 4", 'desc': "..."},
{'title': "Episode 5", 'desc': "..."},
{'title': "Episode 6", 'desc': "..."}]})
episode = db['dvds'].find_one({'episodes.title': "Episode 1"},
fields=['episodes'])
在这个例子中, episode
是:
{u'_id': ObjectId('...'),
u'episodes': [{u'desc': u'...', u'title': u'Episode 1'},
{u'desc': u'...', u'title': u'Episode 2'},
{u'desc': u'...', u'title': u'Episode 3'},
{u'desc': u'...', u'title': u'Episode 4'},
{u'desc': u'...', u'title': u'Episode 5'},
{u'desc': u'...', u'title': u'Episode 6'}]}
但我只想:
{u'desc': u'...', u'title': u'Episode 1'}
解决方案
这同一个问题被问过蒙戈DB谷歌网上论坛页面上。显然,它目前还没有可能的,但它计划在未来。
http://groups.google.com/group/mongodb -user / browse_thread /线程/ 4e6f5a0bac1abccc#
其他提示
我想你想是这样的:
print db.dvds.aggregate([
{"$unwind": "$episodes"}, # One document per episode
{"$match": {"episodes.title": "Episode 1"} }, # Selects (filters)
{"$group": {"_id": "$_id", # Put documents together again
"episodes": {"$push": "$episodes"},
"title": {"$first": "$title"} # Just take any title
}
},
])["result"]
输出(除了空格)是:
[ { u'episodes': [ { u'title': u'Episode 1',
u'desc': u'...'
}
],
u'_id': ObjectId('51542645a0c6dc4da77a65b6'),
u'title': u'The Hitchhikers Guide to the Galaxy'
}
]
如果你想从u"_id"
摆脱,追加与管道:
{"$project": {"_id": 0,
"episodes": "$episodes",
"title": "$title"}
}
的javascript壳在 http://docs.mongodb.org/manual记载MongoDB的/参考/方法/
如果你想找回只有一个对象的特定字段,可以使用
db.collection.find( { }, {fieldName:true});
如果,在另一方面,你正在寻找含有特定字段的对象,可以告
db.collection.find( { fieldName : { $exists : true } } );
搭配更简单:
db['dvd'].find_one( {'episodes.title': "Episode 1"},{'episodes.title': true} )
询问:
coll.find( criteria, fields );
仅从对象中获取特定字段。例如。:
coll.find( {}, {name:true} );
看 db.eval :
您应该做的是这样的:
episode = connection['dvds'].eval('function(title){
var t = db.dvds.findOne({"episodes.title" : title},{episodes:true});
if (!t) return null;
for (var i in t.episodes) if (t.episodes[i].title == title) return t.episodes[i];
}', "Episode 1");
所以发作的滤波将是一个服务器端。
我也遇到了同样的问题。 我这样做的方式是使用聚合函数。首先放松,然后进行匹配。
db.dvds.aggregate([{$unwind:"$episodes"},{$match:{"episodes.title":"Episode 1"}}])
的结果将是象
{ "_id" : ObjectId("5a129c9e6944555b122c8511"),
"title" : "The Hitchhikers Guide to the Galaxy",
"episodes" : { "title" : "Episode 1", "desc" : "..." } }
这不是完美的,但你可以通过蟒蛇编辑。
不隶属于 StackOverflow