无法跨属性NestJS和TypeORM进行一对多查询

Cannot query across one-to-many for property NestJS and TypeORM(无法跨属性NestJS和TypeORM进行一对多查询)

本文介绍了无法跨属性NestJS和TypeORM进行一对多查询的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有两个实体,一个是car,另一个是carAvailability

import { Entity, Column, PrimaryGeneratedColumn, OneToMany } from 'typeorm';
import { CarAvailability } from 'src/car-availabilitys/car-availability.entity';

@Entity('cars')
export class Car {
  @PrimaryGeneratedColumn()
  id: number;

  @Column()
  name: string;

  @OneToMany(() => CarAvailability, (carAvailability) => carAvailability.car, {
    eager: true,
    cascade: true,
  })
  availabilities: CarAvailability[];
}

我正在尝试添加一个根据可用性查询和过滤汽车的服务。在我的服务中,并尝试了两种方式:

带回购函数的方法1:

async test () {
  const startDateTime = '2012-04-24 02:25:43.511';

  return await this.repo.find({
    relations: ['availabilities'],
    where: {
      availabilities: {
        start_date_time: startDateTime
      }
    }
  });
}

使用查询构建器的方法2:

async test () {
  const startDateTime = '2012-04-24 02:25:43.511';

  return this.repo.createQueryBuilder('cars')
    .innerJoin('cars.availabilities', 'car_availabilities')
    .where("cars.availabilities.start_date_time = :startDateTime", { startDateTime })
    .getMany();
}

方法1错误:

Error: Cannot query across one-to-many for property availabilities

方法2错误:

QueryFailedError: missing FROM-clause entry for table "availabilities"

我觉得我好像错过了什么,但我不确定。我同时引用了NestJS和TypeORM文档,但似乎找不出哪里出了问题。

推荐答案

使用方法2,您的where子句应该是

car_availabilities.start_date_time

不是:

cars.availabilities.start_date_time

这篇关于无法跨属性NestJS和TypeORM进行一对多查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:无法跨属性NestJS和TypeORM进行一对多查询

基础教程推荐