Mongoengine:查询 MapField

Posted

技术标签:

【中文标题】Mongoengine:查询 MapField【英文标题】:Mongoengine: Query a MapField 【发布时间】:2017-09-11 00:41:51 【问题描述】:

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

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_id: DeviceProfile object

我试过:User.objects(profiles__device_id=device_id) 无济于事。如何查询以便仅返回在配置文件字段中具有特定键的用户对象?基本上,我想根据设备 ID 查询包含某个 DeviceProfile 对象的用户文档。

【问题讨论】:

【参考方案1】:

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

为了通过 map 字段的键检索 Mongoengine 文档,您使用 exists 运算符。例如,可以构造查询,然后传递给对象方法:

qry = 
    'profiles____exists'.format(key): True,
    '_cls': 'User'


User.object(**qry)

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

Users.object(profiles__exists=key)

将返回所有具有非空 MapField 的对象。

【讨论】:

以上是关于Mongoengine:查询 MapField的主要内容,如果未能解决你的问题,请参考以下文章

mongoengine 参考字段查询

MongoDB:运行更快的查询,这更好 Pymongo 或 MongoEngine

如何在 Python 中使用 MongoEngine 查询 MongoDB 中的特定文档?

Mongoengine Q 类“或”

MongoEngine geo_within_box 不适用于多边形

MongoEngine:关闭连接