MongoDB запрашивают для возврата только встроенного документа

предположите, что у меня есть a BlogPost модель со встроенным zero-many 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'}
15
задан BalusC 17 February 2010 в 03:05
поделиться

4 ответа

Этот же вопрос был задан на странице Mongo DB Google Groups. Судя по всему, в настоящее время это невозможно, но планируется в будущем.

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

6
ответ дан 1 December 2019 в 04:17
поделиться

Оболочка mongodb javascript документирована на http://docs.mongodb.org/manual/reference/method/

Если вы хотите получить обратно только определенные поля объекта, вы можете использовать

db.collection.find( { }, {fieldName:true});

Если, с другой стороны, вы ищете объекты, которые содержат определенное поле, вы можете подать иск

db.collection.find( { fieldName : { $exists : true } } );
2
ответ дан 1 December 2019 в 04:17
поделиться

Посмотрите на 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");

, чтобы фильтрация эпизодов происходила на стороне сервера.

0
ответ дан 1 December 2019 в 04:17
поделиться

Подберите более простой:

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/dbshell+Reference

1
ответ дан 1 December 2019 в 04:17
поделиться
Другие вопросы по тегам:

Похожие вопросы: