Domanda

supporre che ho un modello di BlogPost con zero-a-molti documenti Comment incorporati. posso interrogare per avere e ritorno MongoDB solo oggetti Comment uguagliano mia domanda specifica?

ad esempio, db.blog_posts.find({"comment.submitter": "some_name"}) restituisce solo un elenco di commenti.

modifica: un esempio:

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'])

In questo esempio, 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'}]}

, ma voglio solo:

{u'desc': u'...', u'title': u'Episode 1'}
È stato utile?

Soluzione

Questa stessa domanda è stata posta sopra nella pagina di Mongo DB di Google Gruppi. A quanto pare la sua non è attualmente possibile, ma si prevede per il futuro.

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

Altri suggerimenti

Credo che quello che volevi è questo:

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

L'uscita (oltre agli spazi bianchi) è:

[ { u'episodes': [ { u'title': u'Episode 1',
                     u'desc': u'...'
                   }
                 ],
    u'_id': ObjectId('51542645a0c6dc4da77a65b6'),
    u'title': u'The Hitchhikers Guide to the Galaxy'
  }
]

Se si vuole sbarazzarsi dal u"_id", aggiungere il gasdotto con:

  {"$project": {"_id": 0,
                "episodes": "$episodes",
                "title": "$title"}
               }

Il mongodb JavaScript shell è documentato http://docs.mongodb.org/manual / riferimento / metodo /

Se si vuole tornare solo i campi specifici di un oggetto, è possibile utilizzare

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

Se, d'altra parte, siete alla ricerca di oggetti che contengono un campo specifico, è possibile citare in giudizio

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

Partita più semplice:

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

Domanda:

coll.find( criteria, fields );

Ottenere i campi appena specifici dall'oggetto. Es .:

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

http://www.mongodb.org/display/DOCS/dbshell+Reference

db.eval :

Si dovrebbe fare qualcosa di simile:

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

così il filtraggio degli episodi sarà su un lato server.

Ho anche incontrato lo stesso problema. Il mio modo di fare è utilizzare la funzione di aggregazione. Prima rilassarsi e poi abbinarlo.

db.dvds.aggregate([{$unwind:"$episodes"},{$match:{"episodes.title":"Episode 1"}}])

I risultati saranno come

{ "_id" : ObjectId("5a129c9e6944555b122c8511"),
   "title" : "The Hitchhikers Guide to the Galaxy",
   "episodes" : { "title" : "Episode 1", "desc" : "..." } }

Non è perfetto, ma poi si può modificarlo da Python.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top