7

给定以下实体定义:

@Entity()
export class User extends BaseEntity {
  @Column({ nullable: true })
  name!: string | null;
  
  @Column()
  age!: number;
}

出现以下错误:

typeORM:   "message": "Data type \"Object\" in \"User.name" is not supported by \"postgres\" database."

...

name: 'DataTypeNotSupportedError',
  message:
   'Data type "Object" in "User.name" is not supported by "postgres" database.' }

在查看构建时,我看到 TS 发出的元数据将其作为对象处理:

__decorate([
    typeorm_1.Column({ nullable: true }),
    __metadata("design:type", Object)
], User.prototype, "name", void 0);

我究竟做错了什么?

4

2 回答 2

9

您需要明确提供数据类型。

@Column({ type: 'varchar', nullable: true })
name: string | null;
于 2021-05-14T14:13:11.000 回答
7

问题源于这里的这一部分:

@Column({ nullable: true })
name!: string | null;

创建联合类型时,反射类型将为Object. 克服它的一种简单方法是执行以下操作:

@Column({ nullable: true })
name?: string;
于 2020-10-14T09:54:50.547 回答