문제

내가 가지고 있다고 가정합니다 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'}
도움이 되었습니까?

해결책

이 같은 질문은 Mongo DB Google Groups 페이지에서 이루어졌습니다. 분명히 현재는 불가능하지만 미래를 위해 계획되어 있습니다.

http://groups.google.com/group/mongodb-user/browse_thread/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"}
               }

MongoDB JavaScript 쉘은 문서화되어 있습니다 http://docs.mongodb.org/manual/reference/method/

객체의 특정 필드 만 되돌려 보려면 사용할 수 있습니다.

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

http://www.mongodb.org/display/docs/dbshell+ reference

보다 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" : "..." } }

완벽하지는 않지만 Python으로 편집 할 수 있습니다.

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top