在pymongo中使用$或子句

时间:2011-01-01 19:17:07

标签: mongodb pymongo

我在集合中有这些字段:

[{
     u'_id': ObjectId('4d1f7b4d5d256b18c8000000'),
     u'name': u'1'
 },{
     u'_id': ObjectId('4d1f7b505d256b18c8000001'),
     u'name': u'2'
 },{
     u'_id': ObjectId('4d1f7b525d256b18c8000002'),
     u'name': u'3'
 }]

然后我这样做一个查询:

 [x for x in c.things.find( {'$or' : [{'name':'1'}, {'name':'2'}] } )]

我希望得到:

[{
    u'_id': ObjectId('4d1f7b4d5d256b18c8000000'),
    u'name': u'1'
}, {
    u'_id': ObjectId('4d1f7b505d256b18c8000001'),
    u'name': u'2'
}]

不幸的是没有。我做错了什么?

1 个答案:

答案 0 :(得分:5)

我使用的是超过1.5.3的ubuntu存储库中的mongodb(mongodb的文档说$或者是从1.5.3开始)。 在我更改到最新版本(1.6.5)后,一切都按预期工作。