javascript - 无法跨一对多查询属性 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();
}
方法一错误:
Error: Cannot query across one-to-many for property availabilities
方法二错误:
QueryFailedError: missing FROM-clause entry for table "availabilities"
我觉得我错过了一些东西,但我不确定。参考了 NestJS 和 TypeORM 文档,但似乎无法弄清楚出了什么问题。
解决方案
将方法 1 存储库函数与嵌套查询生成器一起使用:
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
});
}
});
}
推荐阅读
- reactjs - React Firebase useList 钩子中的 Firebase .once()
- python - 如何在递归调用中只打印一次语句?Python
- excel - 如何从excel vba表单中的文本框文本填充组合框值
- java - 二级缓存如何影响hibernate中的批处理?
- database - 如何在 odoo v13 postgresql 数据库中更新或更改成本价格(标准价格)?
- enums - 如何将枚举值传递给函数?
- c# - 捕获异常后如何返回第一个输入?
- azure - Azure 管道中未创建任何项目
- java - 在类图中使用递归关系或“猪耳朵”
- r - 如何使用 for 循环附加列表?