5

我正在尝试在一个查询中执行 3 个唯一搜索。问题是我的搜索“过滤器”类型在架构中是强制性的,但在前端它是可选的。如果在我的过滤器中提供了一个空值,那么我会得到一个 graphql 错误。

我想跳过搜索 mainSearchData、firstComparisonSearchData 或 secondComparisonSearchData,具体取决于搜索过滤器是否包含数据。

我知道我可以使用该skip函数忽略整个查询,但我怎样才能对部分查询实现相同的效果?或者,我怎样才能将这些组合为单独的查询,但只执行一个请求?

const GROWTH_QUERY = gql`query aggregateQuery($mainFilter: filter!, $firstComparisonFilter: filter!, $secondComparisonFilter: filter! $interval: interval!) {
  mainSearchData: groupBy(filter: $mainFilter, first: 20, after: 0) {
    items: publicationDate(interval: $interval, minDocCount: 1, sort: DESC) {
      date
      count
    }
  }
  firstComparisonSearchData: groupBy(filter: $firstComparisonFilter, first: 20, after: 0) {
    items: publicationDate(interval: $interval, minDocCount: 1, sort: DESC) {
      date
      count
    }
  }
  secondComparisonSearchData: groupBy(filter: $secondComparisonFilter, first: 20, after: 0) {
    items: publicationDate(interval: $interval, minDocCount: 1, sort: DESC) {
      date
      count
    }
  }
}`;
4

1 回答 1

8

您可以skip在字段本身上使用该功能。

例如:

const GROWTH_QUERY = gql`query aggregateQuery($mainFilter: filter!, $firstComparisonFilter: filter!, $secondComparisonFilter: filter! $interval: interval!) @skip(if: ...) {
  mainSearchData: groupBy(filter: $mainFilter, first: 20, after: 0) {
    items: publicationDate(interval: $interval, minDocCount: 1, sort: DESC) {
      date
      count
    }
  }
  firstComparisonSearchData: groupBy(filter: $firstComparisonFilter, first: 20, after: 0) @skip(if: ...) {
    items: publicationDate(interval: $interval, minDocCount: 1, sort: DESC) {
      date
      count
    }
  }
  secondComparisonSearchData: groupBy(filter: $secondComparisonFilter, first: 20, after: 0) @skip(if: ...) {
    items: publicationDate(interval: $interval, minDocCount: 1, sort: DESC) {
      date
      count
    }
  }
}`;

请注意@skip(if: ...)别名调用 、 和 之后mainSearchDatafirstComparisonSearchData语句secondComparisonSearchData

于 2017-05-10T22:25:17.943 回答