首页 > 解决方案 > 在执行 $aggrigate $lookup 之后,如何将某些字段的过滤器添加为可选?需要进行哪些更改?

问题描述

我想按学科和年级以及其他一些领域获取数据...................... ..................................................... ..................................................... ..................................................... ..................................................

 
   const skip = Number(page) === 1 ? 0 : Number(perPage) * (Number(page) - 1);
   const limit = Number(skip) + Number(perPage);
 
   let queryData: any = {};`enter code here`
   
   if (grade != null) {
     queryData.grade = grade;
   }
   
   if (subjects != null) {
     queryData.subjects = subjects;
   }
  let teacherData= await this.teacherModel.aggregate([

   {
     $lookup: {
       from: "eclasses",
       localField: "_id",
       foreignField: "teacher",
       as: "classes"
     }
   },
   
   {
     $lookup: {
       from: "courses",
       localField: "_id",
       foreignField: "teachers.id",
       as:"course",
     }
     
   },
   {
     $project:{firstName:1, lastName:1,"classes.grade":1,"classes.subject":1,"classes.name":1,"course._id":1}
   } ,
   {       
     $match: {...queryData}
   },
   {
     $facet: {
       TeacherRecord: [{ $skip: skip }, { $limit: limit }],
       metadata: [{ $count: "total" }, { $addFields: { page: page } }],
     },
   },
   
  
 ])
 const totalCount = teacherData[0]?.total
 const getPaginationResult = PaginationHandle.getPageCount(
   page,
   perPage,
   totalCount
 );

 return [ teacherData,getPaginationResult];

 }```

标签: javascriptnode.jsmongodbnestjs

解决方案


推荐阅读