首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Mongoengine:查询MapField

Mongoengine:查询MapField
EN

Stack Overflow用户
提问于 2017-04-14 18:08:21
回答 1查看 2K关注 0票数 3

我有一个要查询的地图字段。类似于:

代码语言:javascript
复制
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对象。

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-04-15 16:27:42

把这个留给其他遇到这个问题的人。

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

代码语言:javascript
复制
qry = {
    'profiles__{}__exists'.format(key): True,
    '_cls': 'User'
}

User.object(**qry)

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

代码语言:javascript
复制
Users.object(profiles__exists=key)

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

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43416883

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档