[英]ER_PARSE_ERROR in Nest js
您好,我对 NestJS 中的关系有疑问。
我试图让用户与名为 club 这样的关系:
async findOne(id: number): Promise<User> {
return this.userRepository.findOne({
where: { id: id },
relations: ['club'],
});
}
这会引发此错误:
ER_PARSE_ERROR: You have an error in your SQL syntax;
check the manual that corresponds to your MariaDB server version for the right syntax to use near 'WHERE `User`.`id` = 1) `distinct Alias` ORDER BY `User_id` ASC LIMIT 1' at line 1
我认为我的实体看起来是正确的,MariaDB 有问题吗?
有我的用户实体:
export class User {
@PrimaryGeneratedColumn()
id: number;
@Column()
@Unique('email_unique', ['email'])
email: string;
@Column()
@Unique('username_unique', ['username'])
username: string;
@Column()
password: string;
@Column({ type: 'boolean' })
active = false;
@Column()
activationToken: string;
@OneToOne(() => Club, (club) => club.user)
club: Club;
}
和俱乐部实体:
@Entity()
export class Club {
@PrimaryGeneratedColumn()
id: number;
@ManyToOne(() => League)
league: League;
@OneToOne(() => User, (user) => user.club)
user: User;
@Column()
name: string;
@Column()
location: string;
@OneToMany(() => Player, (player) => player.club)
players: Player[];
}
您缺少JoinColumn
注释 - 这可能是错误生成 sql 的原因。 尝试在拥有JoinColumn
,例如
export class User {
// ...
@OneToOne(() => Club, (club) => club.user)
@JoinColumn()
club: Club;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.