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();