GraphQL中的双向提取

时间:2015-09-23 08:47:30

标签: reactjs relay graphql graphql-js

我有以下GraphQL架构:

interface Node {
  id: ID!
}

type User : Node {
  id: ID!
  name: String!
  tasks: [Task]
}

type Task : Node {
  id: ID!
  day: Int!
  description: String!
}

type Viewer {
  users: [User]
}

type Query {
  viewer: Viewer
}

基本上,每个用户都可以拥有任务列表。当我需要获取所有任务的获取列表以获得响应时,会出现问题:

tasks: [{
  day: 1,
  user: {
    name: "John"
  }
}, {
  day: 2,
  user: {
    name: "Jane"
  }
}]

我应该如何编辑我的架构以允许这样的提取?

1 个答案:

答案 0 :(得分:2)

为了能够获取所有任务的列表,请将其作为属性添加到Viewer

type Viewer {
  users: [User]
  tasks: [Task]
}

并将users字段添加到Task

type Task : Node {
  id: ID!
  day: Int!
  description: String!
  users: [User]
}

使用更新的架构,您可以查询所有用户和任务的列表:

{
  viewer {
    users {  // all users
      name
      tasks {  // user's tasks
        description
      }
    }
    tasks {  // all tasks
      day
      users {  // task's users
        name
      }
    }
  }
}

此外,您应该使用分页而不是一次性获取所有任务(或用户)。如果您计划将GraphQL服务器与Relay一起使用,请将您的用户/任务定义为List,而不是具有边缘的Connection。见https://facebook.github.io/relay/docs/graphql-connections.html#content