【问题标题】:Cannot query across one-to-many for property NestJS and TypeORM无法跨一对多查询属性 NestJS 和 TypeORM
【发布时间】:2021-11-26 23:53:12
【问题描述】:

我有两个实体,一个是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[];
}

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

带有repo函数的方法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();
}

方法一错误:

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

方法二错误:

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

我觉得我错过了什么,但我不确定。参考了 NestJS 和 TypeORM 文档,但似乎无法弄清楚出了什么问题。

【问题讨论】:

    标签: javascript postgresql nestjs typeorm


    【解决方案1】:

    将方法 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
          });
        }
      });
    }
    

    【讨论】:

      【解决方案2】:

      oneToMany一侧删除cascade并放入:

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

      manyToOne 一侧。

      如果你要使用关系:['availabilities'],你可以删除eager: true

      【讨论】:

        【解决方案3】:

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

        car_availabilities.start_date_time
        

        不是:

        cars.availabilities.start_date_time
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 2022-01-15
          • 1970-01-01
          • 2020-10-09
          • 2021-02-27
          • 2020-08-29
          • 2019-07-27
          • 2020-09-03
          相关资源
          最近更新 更多