Nest.js Typrorm 多对多关系如何创建

Published on
3 mins read
––– views
thumbnail-image

使用 Typeorm 创建多对多关系的时候,可按以下方法进行。

以 Article 和 Tag 的关系为例:

@Entity()
export class Article extends CommonEntity {
    // ...

    // 标签
    @ManyToMany(() => Tag, (tag) => tag.articles)
    @JoinTable()
    tags: Tag[];
}
@Entity()
export class Tag extends CommonEntity {
    // 标签名
    @Column()
    @IsNotEmpty()
    label: string;

    // 使用的文章
    @ManyToMany(() => Article, (article) => article.tags)
    articles: Article[];
}
@Module({
    imports: [TypeOrmModule.forFeature([Tag])],
    controllers: [TagController],
    providers: [TagService],
    exports: [TagService],
})
export class TagModule {}
@Module({
    imports: [TypeOrmModule.forFeature([Article]), TagModule],
    controllers: [ArticleController],
    providers: [ArticleService],
})
export class ArticleModule {}

在 article.service.ts 中调用 Tag.Service.ts 中的方法:

@Injectable()
export class ArticleService {
    list: any[];
    constructor(
        @InjectRepository(Article)
        private readonly articleRepository: Repository<Article>,
        private readonly tagService: TagService,
    ) {}

		/**
     * 创建文章
     * @param articleCreateDto
     * @returns
     */
    async create(articleCreateDto: ArticleCreateDto) {

        // ...

				// 在此处就可以使用 this.tagService 来调用 Tag.service 中的方法了
        const tags = await this.tagService.findByIds(ids);
        console.log('所有 tag id:',ids, '文章中的tags',tags);

	      // ...

    }
}

⚠️ 注意:

  • 在 article.service 中调用 tag.service 中的方法的时候要先在 article.module 中 imports 导入 TagModule 模块。

  • 还需要在 tag.module 中 exports TagService,否则报以下错。

    Nest can't resolve dependencies of the ArticleService (ArticleRepository, ?). Please make sure that the argument TagService at index [1] is available in the ArticleModule context.
    
    Potential solutions:
    - Is ArticleModule a valid NestJS module?
    - If TagService is a provider, is it part of the current ArticleModule?
    - If TagService is exported from a separate @Module, is that module imported within ArticleModule?
      @Module({
        imports: [ /* the Module containing TagService */ ]
      })
    

我一开始以为像普通 js 一样直接在 article.service 中导入就可以使用 tag.service 中的方法,导致一直报错,后来发现需要在 article.module 中导入 TagModule 模块才可以。

后来导入之后还是报错,就是上边这个错⬆️,最后才发现要先导出 tag.module 中先导出 TagService 才可以。

angular 的思想和普通 js 差别好大啊 😂 …

Built with
-View source
Copyright © 2024
Mengke's blog - Mengke's coding journey