是我在这里的第一个问题。 我的问题是我想从数组联系人中获取一个带有 _id 的对象联系人:{ type: [contactSchema] in an Object Customer。但我得到了洞对象客户。
router.route('/customers/:id/contact/:contacts_id').get((req, res) => {
Customer.findOne({
"_id": req.params.id,
"contacts._id": req.params.contacts_id
},
(err, customer) => {
if (err)
console.log(err);
else
res.json(customer);
}
)
})
如果我使用 Contact.findOne,我会得到 null。
答案 0 :(得分:0)
由于您正在查询客户,因此您的查询将返回一个客户对象。但是,使用 projections,您可以隐藏查询返回的对象的属性。最重要的是,elemmatch 可用于在数组中查找匹配项
以下是在您的情况下如何使用它们:
Customer.findOne(
{_id: req.params.id},
{ projection: { _id: 0, contacts: { $elemMatch: { _id: req.params.contacts_id } } },
(err, customer) => {
if (err) console.log(err);
else res.json(customer);
}
)
答案 1 :(得分:0)
router.route('/customers/:id/contact/:contacts_id').get((req, res) => {
Customer.findOne({
"_id": mongoose.Types.ObjectId(req.params.id),
"contacts._id": mongoose.Types.ObjectId(req.params.contacts_id)
},
(err, customer) => {
if (err)
console.log(err);
else
res.json(customer);
}
)
})