2010-02-15 14 views
15

मान लीजिए कि मेरे पास BlogPost मॉडल है जो शून्य से कई एम्बेडेड Comment दस्तावेज़ों के साथ है। क्या मैं पूछताछ कर सकता हूं और मोंगोडीबी रिटर्न केवल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'} 
+0

स्वीकृत उत्तर का "भविष्य" अब अतीत है, क्योंकि समेकन ढांचा पहले से मौजूद है। मैंने जवाब दिया कि यह कैसे करें। –

उत्तर

2

MongoDB जावास्क्रिप्ट खोल http://docs.mongodb.org/manual/reference/method/ पर दर्ज है

तुम वापस प्राप्त करना चाहते हैं एक वस्तु के केवल विशिष्ट क्षेत्रों, आप उपयोग कर सकते

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

दूसरे हाथ पर, आप देख रहे हैं, तो जिन वस्तुओं पर एक विशेष क्षेत्र को शामिल करने के लिए, आप पर मुकदमा कर सकते हैं

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

मैंने मूल प्रश्न में एक उदाहरण के साथ अपने प्रश्न को स्पष्ट करने की कोशिश की है। धन्यवाद। – Carson

0

देखो:

आप की तरह कुछ करना चाहिए:

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

तो प्रकरणों की छानने एक सर्वर साइड पर होगा।

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

7

मुझे लगता है कि क्या आप चाहते थे यह है:

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

मैं भी एक ही समस्या से मुलाकात की। मैं जिस तरह से करता हूं वह कुल कार्य का उपयोग करता है।पहले इसे खोलें और फिर इसे मैच करें।

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

की तरह यह सही नहीं है, लेकिन फिर आप यह अजगर द्वारा संपादित कर सकते हैं।

संबंधित मुद्दे