gpt4 book ai didi

MongoDB查询仅返回嵌入文档

转载 作者:IT老高 更新时间:2023-10-28 13:08:38 24 4
gpt4 key购买 nike

假设我有一个 BlogPost 模型,其中包含零对多嵌入的 Comment 文档。我可以查询并让 MongoDB 返回与我的查询规范匹配的 only 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'}

最佳答案

我想你想要的是这样的:

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"}
}

关于MongoDB查询仅返回嵌入文档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2268568/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com