如何使用Apollo GraphQL使用Mongoose Aggregate Lookup返回id



我有一个聚合函数,它返回集合中的人员:

const getById = ({ id }) => {
return Project.aggregate([
{ $match: { _id: Types.ObjectId(id) } },
{
$lookup: {
from: "members",
localField: "_id",
foreignField: "project_id",
as: "members"
}
},
])
.then(data => {
const [project] = data;
console.log(project) // see below
return {
id: project._id,
...project
};
})
.catch(err => console.log(err));
}

如果我从中返回数据,我会得到以下信息:

// Server response
{ _id: 5e2f57b577a8ce59c79e74af,
title: 'ok',
user_id: 5e2dc7961e6b840c315b5a03,
__v: 0,
members:
[ { _id: 5e447683b4f732cc9c4a9531,
name: 'Karl Taylor',
email: 'karl@queuey.dev',
project_id: 5e2f57b577a8ce59c79e74af,
position: 1,
__v: 0 },
{ _id: 5e45be128ed96a5eaef5d13e,
name: 'John Smith',
email: 'john@queuey.dev',
project_id: 5e2f57b577a8ce59c79e74af,
position: 2,
__v: 0 } ] }

但是,当我使用Apollo GraphQL从前端查询时,id为null。(但它适用于其他项,因为idid的getter,但这不会发生在聚合函数上(。

id映射到正确值的最佳做法是什么?我通常只会使用array.map,但我觉得如果我有太多的成员,那可能太过分了(在这一点上,我可能会打破它来进行分页,但那是另一回事。(

这是前端的响应

// Client response
"project": {
"id": "5e2f57b577a8ce59c79e74af",
"title": "ok",
"members": [
{
"id": null, // <-- Notice here is null
"name": "Karl Taylor",
"email": "karl@queuey.dev",
"__typename": "Member"
},
{
"id": null, // <-- Notice here is null
"name": "John Smith",
"email": "john@queuey.dev",
"__typename": "Member"
}
],
"__typename": "Project"
}

这里的这个问题是类似的,但是,我不认为它是重复的,因为我们正在查询不同的数据。(答案不能解决我的问题。(

我需要能够返回id,否则缓存的重定向将无法工作。

我在尝试使用聚合时也遇到了这个问题。简单地说,你可以同时拥有ID(id_id(,但这不是一件好事。

我使用的是迭代数据

如果查询的返回数据不是数组,请使用此

return {
...res._doc,
id: res._id,
}

但是返回的数据是一个数组,您可以使用forEachid添加到响应变量中,如下所示

res.forEach(element => {
element.id = element._id 
});
return res;

最新更新