6

我在猫鼬中有一个 Person 对象,并且该 person 对象有多个东西(每个东西都有一个唯一的 ID)。

person1 = {
  things[{id: 1, name: 'one'},{id:2, name: 'two'}]
}
person2 = {
  things[{id: 3, name: 'three'},{id:4, name: 'four'}]
}

然后查询:

Person.findOne({'things.id': 2},{'things.$': 1}, function(err, person) { ...

这很好用,但我正在搜索所有 Person 对象(可能有很多)。在这种情况下,我知道我需要的人的 id 和“事物”的一些唯一 id。通过 id 获取 Person 可能要快得多:

Person.findById(personId, function(err, person) { ...

然后遍历所有内容以找到正确的内容:

var thing
person.things.forEach(function(t) {
  if (t.id == thingId) {
    thing = t;
  }
});

我想知道是否有更好的方法。IE 我可以通过 id 查询 Person 集合以获取一个 Person 然后过滤掉我正在寻找的东西(没有丑陋的循环)吗?

4

1 回答 1

19

您可以在单个查询中包含两个 id 术语,并且单个元素投影仍然有效:

Person.findOne({_id: personId, 'things.id': 2}, {'things.$': 1}, 
    function(err, person) { ...
于 2013-03-05T02:34:07.517 回答