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进行一对多查询
基础教程推荐
猜你喜欢
- HTML5 画布调整为父级 2022-01-01
- 逻辑运算符 ||在 javascript 中,0 代表 Boolean false? 2022-01-01
- 带角度的选项卡:仅使用 $http 在单击时加载选项卡 2022-01-01
- 即使每次插入第一个输入的值不同,第二个输入仍显示相同的输入值 2022-01-01
- 从快速中间件中排除路由 2022-01-01
- 使用 jQuery 在悬停时交换 DIV 类 2022-01-01
- 在 Javascript 中使用 Fetch API 上传文件并显示进度 2022-01-01
- CORS:当凭据标志为真时,无法在 Access-Control-Allow-Origin 中使用通配符 2022-01-01
- 当木偶师打开Chrome时,不能使用Chrome扩展 2022-01-01
- 最佳动态 JavaScript/JQuery 网格 2022-01-01
