我有两个实体,一个是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文档,但似乎无法找出哪里出错了。
4条答案
按热度按时间rkttyhzu1#
使用方法2时,由于
car.availabilities
别名为car_availabilities
,因此where
子句应使用别名:非:
mtb9vblg2#
使用方法1 repo函数和嵌套查询构建器:
py49o6xq3#
从
oneToMany
侧取下cascade
,并放置:在
manyToOne
侧。如果你要使用关系:
['availabilities']
您可以删除eager: true
。l7wslrjt4#
在async函数后面添加一个.then(),就像我的代码一样