问题描述
我有两个 ID:publisherID 和 BookID。
我的猫鼬数据库看起来像:
现在的问题是:我想找到 userId,其中publisherId 为59l55llopd3W1FuosGgN,bookId 为G1Vfe2NwS3sy-qhT1J0g6
我创建了以下返回空数据的函数。
const allTheRelatedData = (publiserId,bookId) => {
return new Promise((resolve,reject) => {
try {
myBookSchema
.findOne({
publisherId: publisherId,"books.$.bookId": bookId,})
.then((data) => {
console.log(data);
resolve(data);
})
.catch((error) => {
console.log(error);
reject(error);
});
} catch (error) {
console.log(error);
reject(error);
}
});
};
当我运行这段代码时,它给出了空数据。请帮忙,我尝试了很多解决方案,例如位置、匹配等。没有任何效果。请帮忙。
解决方法
也许这会奏效
movd r32,xmm
,
您可以使用 $ projection operator 来做到这一点:
myBookSchema
.findOne({
publisherId: publisherId,"books.bookId": bookId,},{
"books.$": 1
}
).then((data) => {...
然后您可以使用 userId
获得 data.books[0].userId
并记住使用 if (data && data.books && data.books.length)...
检查数据或书籍是否存在