具有 TypeORM Active Record 实现的 Nest.js 项目

rhl*_*hrm 3 typeorm nestjs

我正在尝试使用 Nest.js 和 TypeORM 构建一个项目。我喜欢TypeORM 中的Active Record 方法

我定义一个实体如下,带有一些静态辅助方法:

export class Book extends BaseEntity {
  @PrimaryGeneratedColumn()
  id: number;

  @Column()
  name: string;

  @Column()
  description: string;

  static async createNew(attributes: BookDto): Promise<Book> {
    const entity = new Book();
    entity.name = attributes.name;
    entity.description = attributes.description;

    return entity.save();
  }

  static async findByName(name: string): Promise<Book> {
    return Book.findOne({
      where: { name },
    });
  }
}
Run Code Online (Sandbox Code Playgroud)

我正在尝试遵循 Nest 文档中的模式将其注入我的服务中:

@Injectable()
export class BookService {
  constructor(
    @InjectRepository(Book)
    private readonly bookRepository: Repository<Book>,
  ) {}

  async create(bookAttrs: BookDto): Promise<Book> {
    return Book.createNew(bookAttrs);
  }
}
Run Code Online (Sandbox Code Playgroud)

但正如您在我的服务中看到的,我只使用静态方法。在这种情况下,我是否需要注入依赖项?我应该遵循更好的模式吗?

Kim*_*ern 6

如果您采用这种方法,则不需要Repository在服务中注入,甚至不需要TypeOrmModule.forFeature([User])在功能模块中导入,因为您没有注入任何与 TypeOrm 相关的内容,因为您正在使用 (global ) 可以在任何地方使用的静态方法。

但是,我不建议这样做,最重要的原因是测试:Nest 为您提供了一种在测试中模拟依赖关系的非常方便的方法。这是唯一可能的,因为您在模块中声明了依赖项,并且注入器决定将使用什么实际实现。当您通过使用静态方法具有隐式依赖项时,很难在单元测试和集成测试中模拟它们,而在数据库访问的情况下您肯定想要这样做。

除了测试之外,当您从任何地方进行静态访问时,您的依赖关系可能会变得混乱。在模块中具有声明性依赖关系对于保持代码整洁非常有用。