TypeGraphQL 使用 TypeORM 的 findAndCount 方法

Mat*_*tis 1 pagination typescript typeorm typegraphql

我想使用TypeORMfindAndCount函数返回Promise<[Entity[], number]>分页。所以我有一个解析器:

offers(@Arg('page', { defaultValue: 1 }) page: number): Promise<[Offer[], number]> {
    const COUNT = 10
    return this.offerRepository.findAndCount({ take: COUNT, skip: (page - 1) * COUNT })
}
Run Code Online (Sandbox Code Playgroud)

我也在使用type-graphql并想用这样的Query注释来注释这个解析器:

@Query(returns => ???)
Run Code Online (Sandbox Code Playgroud)

但是我无法弄清楚返回类型,我尝试了这个(这当然不起作用,因为findAndCount返回的是什么):

@ObjectType()
class TestType {
    @Field(type => [Offer])
    offers: Offer[]

    @Field()
    count: number
}
Run Code Online (Sandbox Code Playgroud)

并尝试像这样使用它:@Query(returns => [TestType])和 this @Query(returns => TestType)

Mic*_*tek 8

GraphQL 不支持元组,因此您需要创建一个响应对象类型:

@ObjectType()
class OffersResponse {
  @Field(type => [Offer])
  items: Offer[]

  @Field(type => Int)
  totalCount: number
}
Run Code Online (Sandbox Code Playgroud)

然后手动将元组映射到对象:

@Query(returns => OffersResponse)
offers(@Arg('page', { defaultValue: 1 }) page: number): Promise<OffersResponse> {
    const COUNT = 10
    const [items, totalCount] = await this.offerRepository.findAndCount(
      { take: COUNT, skip: (page - 1) * COUNT }
    )
    return { items, totalCount }

}
Run Code Online (Sandbox Code Playgroud)