如何使用Typeorm查询构建器创建查询以从数据库中窃取数据?

时间:2020-03-20 12:15:50

标签: javascript node.js typescript nestjs typeorm

我对typeorm还是陌生的,我正在使用nodejs / nestjs,我试图创建一个查询,其中数据库中的数据可以由讲师的名字和姓氏,课程名和课程名进行过滤。按主题过滤课程。我尝试使用“ where”和“ orWhere”,但似乎无法将其包装起来,任何人都可以提出更好的实现建议吗?谢谢。非常感谢。

下面的查询正在运行,我遇到了“ where”条件

代码

async findAll(options: IPaginationOptions, query): Promise<Pagination<CourseEntity>> {
    console.log('query :', query);
    const courses = await getRepository(CourseEntity)
      .createQueryBuilder('course')
      .leftJoinAndSelect('course.user', 'user')
      .leftJoinAndSelect('course.subject', 'subject')
      // eslint-disable-next-line @typescript-eslint/camelcase
      .where('course.course_name = :course_name', { course_name: query.course_name });

    return paginate<CourseEntity>(courses, options);
  }

这是查询参数

query : { limit: '10', firstname: 'mark', lastname: 'gunn' , course_name: 'Comscie'}

从数据库中采样数据

 {
            "id": 4,
            "course_name": "BS-IT",
            "description": "BS-IT DBMS",
            "created": "2020-03-19T16:40:46.000Z",
            "updated": "2020-03-19T16:40:46.000Z",
            "user": {
                "id": 20,
                "firstname": "Mark",
                "lastname": "Gunn",
                "role": "Instructor",
                "email": "mark@gmail.com",
                "isActive": false,
                "created": "2020-03-19T16:06:21.000Z",
                "updated": "2020-03-19T16:06:34.000Z"
            },
            "subject": {
                "id": 2,
                "subject_name": "IT 100",
                "description": "Fundamandetals",
                "created": "2020-03-18T03:58:34.000Z",
                "updated": "2020-03-18T03:58:34.000Z"
            }
        }

2 个答案:

答案 0 :(得分:0)

看起来不错。只需使用andWhere

添加其他条件

答案 1 :(得分:0)

对于使用Typeorm的项目,我更喜欢使用Find Option Object(https://typeorm.io/#/find-options),因为从对象生成请求更容易,但是您无法进行一些高级联接(但是在您的情况下完全可以)

它们不是更好的实现,只是多个解决方案。