16

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'}
4

6 に答える 6

8

あなたが望んでいたのはこれだと思います:

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"}
               }
于 2013-03-28T11:25:44.887 に答える
6

これと同じ質問がMongoDBのGoogleグループページで行われました。どうやら現在は不可能ですが、将来的に計画されています。

http://groups.google.com/group/mongodb-user/browse_thread/thread/4e6f5a0bac1abccc#

于 2010-02-15T22:34:20.553 に答える
1

より単純に一致させる:

db['dvd'].find_one( {'episodes.title': "Episode 1"},{'episodes.title': true} )

クエリ:

coll.find( criteria, fields );

オブジェクトから特定のフィールドだけを取得します。例えば:

coll.find( {}, {name:true} );

http://www.mongodb.org/display/DOCS/dbshel​​l+Reference

于 2010-05-10T04:11:44.393 に答える
0

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");

そのため、エピソードのフィルタリングはサーバー側で行われます。

于 2010-02-15T22:59:39.977 に答える