Javascript 输入存在时MongoDB匹配(聚合)
仅当提交了Javascript 输入存在时MongoDB匹配(聚合),javascript,mongodb,mongoose,aggregate,Javascript,Mongodb,Mongoose,Aggregate,仅当提交了userId时,我才尝试匹配用户。最好的方法是什么。您可以使用,根据您的条件管理聚合阶段 $match: { date: { $gte: fromDate, $lte: toDate }, if (userId) { user: userId } }, 聚合将自动合并$match阶段,如果两者同时存在 第二种选择: // INITIALIZE let p = YourSchemaModel.aggregate(); // DATE FILTER p.matc
userId
时,我才尝试匹配用户。最好的方法是什么。您可以使用,根据您的条件管理聚合阶段
$match: {
date: { $gte: fromDate, $lte: toDate },
if (userId) {
user: userId
}
},
聚合将自动合并$match
阶段,如果两者同时存在
第二种选择:
// INITIALIZE
let p = YourSchemaModel.aggregate();
// DATE FILTER
p.match({ date: { $gte: fromDate, $lte: toDate } });
// USER ID FILTER
if (userId) p.match({ user: userId });
// RESULT
let result = await p.exec();
let result = await YourSchemaModel.aggregate().match(
Object.assign(
{ date: { $gte: fromDate, $lte: toDate } },
userId ? { user: userId } : {}
)
).exec();