繁体   English   中英

Nest js 中的 ER_PARSE_ERROR

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM