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

dbf7pr2w  于 2023-04-05  发布在  PostgreSQL
关注(0)|答案(4)|浏览(161)

我有两个实体,一个是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使用repo函数:

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文档,但似乎无法找出哪里出错了。

rkttyhzu

rkttyhzu1#

使用方法2时,由于car.availabilities别名为car_availabilities,因此where子句应使用别名:

car_availabilities.start_date_time

非:

cars.availabilities.start_date_time
mtb9vblg

mtb9vblg2#

使用方法1 repo函数和嵌套查询构建器:

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

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

py49o6xq3#

oneToMany侧取下cascade,并放置:

{
  cascade: true,
  onDelete: 'CASCADE',
  onUpdate:'CASCADE'
}

manyToOne侧。
如果你要使用关系:['availabilities']您可以删除eager: true

l7wslrjt

l7wslrjt4#

在async函数后面添加一个.then(),就像我的代码一样

return await this.repository.find({relations: ['availabilities'])
.then((cars) => cars.filter((car) => car.start_date_time === startDateTime));

相关问题