Python Mongoengine:查询映射字段

Python Mongoengine:查询映射字段,python,mongodb,python-3.x,mongoengine,odm,Python,Mongodb,Python 3.x,Mongoengine,Odm,我有一个要查询的地图字段。比如: class User(mongoengine.Document): email = mongoengine.EmailField(required=False, unique=False) username = mongoengine.StringField(max_length=30, min_length=6, required=True, unique=True) password = mongoengine.StringField

我有一个要查询的地图字段。比如:

class User(mongoengine.Document):
    email = mongoengine.EmailField(required=False, unique=False)
    username = mongoengine.StringField(max_length=30, min_length=6, required=True, unique=True)
    password = mongoengine.StringField(max_length=500, min_length=6, required=True)
    profiles = mongoengine.MapField(mongoengine.EmbeddedDocumentField(DeviceProfile))
因此,在字段profiles中,我存储了如下对象:device\u id:DeviceProfile object


我尝试了:
User.objects(profiles\uu device\u id=device\u id)
但没有成功。如何进行查询,以便仅返回在profiles字段中具有特定键的用户对象?基本上,我希望根据设备ID查询包含特定DeviceProfile对象的用户文档。

将此信息留给遇到此问题的其他人

要通过映射字段的键检索Mongoengine文档,请使用
exists
操作符。例如,可以构造查询,然后将其传递给object方法:

qry = {
    'profiles__{}__exists'.format(key): True,
    '_cls': 'User'
}

User.object(**qry)
exists
运算符视为“常规”查询不起作用,因为任何非null、非零值都将被视为
True
,匹配将返回MapField中有内容的任何文档。例如:

Users.object(profiles__exists=key)
将返回具有非空映射字段的所有对象