我有以下型号
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)
我编写了以下查询:
Agent.objects.filter(name='ashraf', skills__level__gt=5,skills__name="Computer Skills")如果座席具有名为"Computer skills“且级别为3的技能,并且还具有名为"English skills”且级别为10的技能,则该座席将出现在查询结果中
发布于 2012-02-13 19:17:27
你需要执行一个$elemMatch1查询,目前在mongoengine中还没有内置的支持。您必须执行如下所示的原始查询:
Agent.objects.filter(
name='ashraf',
__raw__={"skills": {
"$elemMatch": {
"level": {"$gt": 5},
"name": "Computer Skills"
}
}}
)http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%24elemMatch
发布于 2012-02-12 02:17:49
我不使用python驱动程序,但是你想要实现的一般Mongo语法是这样的……
db.agent.find({name:'ashraf', 'skills.name' : "computer skills", level:{ $gt: 5}})https://stackoverflow.com/questions/9241408
复制相似问题