2014-03-27 67 views
1

查詢使用pymongo包我想查詢我的蒙戈數據庫返回的每個不同websiteId其中newStatus等於7MongoDB的:由不同的ObjectId

for i in db.mycollection.find({'newStatus': 7}).distinct('websiteId'): 
    pprint(i) 

Unfortunatley這給了我一個TypeError: 'ObjectId' object has no attribute '__getitem__' 因爲websiteId出現是某種ObjectId的東西:

c = db.mycollection.find_one() 
pprint(c) 

{u'date': datetime.datetime(2011, 2, 22, 20, 31, 58, 316000), 
u'newStatus': 7, 
u'oldStatus': 6, 
u'websiteId': ObjectId('4f94c64578a62')} 

有什麼想法?

回答

0

嘗試,如果這個工程 -

db.sample.find() 
{ "_id" : ObjectId("5333764486bee74e9de524ff"), "webstatId" : ObjectId("5333764486bee74e9de524fe"), "siteId" : "27" } 
{ "_id" : ObjectId("5333767a86bee74e9de52500"), "webstatId" : ObjectId("5333764486bee74e9de524fe"), "siteId" : "28" } 

db.sample.distinct('webstatId',{"siteId" : "27"}) 
[ ObjectId("5333764486bee74e9de524fe") ] 

-

connection = pymongo.Connection('mongodb://localhost',safe=True) 
db = connection.test 
sample = db.sample 
query = '\'webstatId\',{"siteId" : "27"}' 

try: 
    print query 
    doc = sample.distinct(query); 
except: 
    print "Unexpected error", sys.exec_info()[0] 
for d in doc: 
    print d 

我在外殼試過這種