首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法通过ListField(EmbeddedDocumentField)进行查询

无法通过ListField(EmbeddedDocumentField)进行查询
EN

Stack Overflow用户
提问于 2012-02-11 23:35:04
回答 2查看 1.2K关注 0票数 3

我有以下型号

代码语言:javascript
复制
class Skill(EmbeddedDocument):
   name =  StringField(required = True)
   level = IntField(required = True)

class Agent(Document):
   name = StringField(required = True)
   email = EmailField(required = True, unique = True)
   skills = ListField(EmbeddedDocumentField(Skill))

我要搜索具备以下技能的座席(name =“计算机技能和级别>5)

我编写了以下查询:

代码语言:javascript
复制
 Agent.objects.filter(name='ashraf',  skills__level__gt=5,skills__name="Computer Skills")

如果座席具有名为"Computer skills“且级别为3的技能,并且还具有名为"English skills”且级别为10的技能,则该座席将出现在查询结果中

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-02-13 19:17:27

你需要执行一个$elemMatch1查询,目前在mongoengine中还没有内置的支持。您必须执行如下所示的原始查询:

代码语言:javascript
复制
Agent.objects.filter(
    name='ashraf',  
    __raw__={"skills": {
        "$elemMatch": {
            "level": {"$gt": 5}, 
            "name": "Computer Skills"
        }
    }}
)

http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%24elemMatch

票数 2
EN

Stack Overflow用户

发布于 2012-02-12 02:17:49

我不使用python驱动程序,但是你想要实现的一般Mongo语法是这样的……

代码语言:javascript
复制
db.agent.find({name:'ashraf', 'skills.name' : "computer skills", level:{ $gt: 5}})
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9241408

复制
相关文章

相似问题

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