美文网首页
GraphQL学习——查询与变更

GraphQL学习——查询与变更

作者: 布蕾布蕾 | 来源:发表于2017-12-18 10:03 被阅读0次

简介

  • GraphQL是一个用于API的查询语言,一个使用基于类型系统来执行查询的服务端运行时
  • GraphQL未与任何特定数据库,存储引擎绑定,而是依靠现有代码和数据支撑

查询和变更

字段(Fields)

  • GraphQL关于请求对象上的特定字段
  • 查询和查询的结果拥有一致的数据结构(很重要)
    • 客户端得到想要的数据
    • 服务器准确知道客户端请求的字段
    • 可以对对象字段进行次级选择
// 查询
{
  hero {
    name
    # 可以添加备注
    friends {
      name
    }
  }
}

// 结果
{
  "data" : {
    "hero": {
      "name": "wxy",
      "friends": [
        {
          "name": "Luke Skywalker"
        },
        {
          "name": "Han Solo"
        },
        {
          "name": "Leia Organa"
        }
      ]
    }
  }
}

参数(Arguments)

  • 每一个字段,嵌套对象都能有自己的一组参数,使得GraphQL可以完美替代多次API获取请求
  • 可以给标量(scalar)字段传递参数,GraphQL自带一套默认类型,也可以自己定制类型,来序列化输出格式
    Schema和类型
// 查询
{
  human(id: "1000") {
    name
    height
  }
}

// 结果
{
  "data": {
    "human": {
      "name": "Luke Skywalker",
      "height": 1.72
    }
  }
}

别名(Aliases)

  • 通过别名,查询相同字段的不同内容
// 查询不同的hero
{
  empireHero: hero(episode: EMPIRE) {
    name
  }
  jediHero: hero(episode: JEDI) {
    name
  }
}

// 通过别名,查询不同的hero
{
  "data": {
    "empireHero": {
      "name": "Luke Skywalker"
    },
    "jediHero": {
      "name": "R2-D2"
    }
  }
}

片段(Fragments)

  • GraphQL可复用单元,好的抽象,可以避免重复代码
{
  leftComparison: hero(episode: EMPIRE) {
    ...comparisonFields
  }
  rightComparison: hero(episode: JEDI) {
    ...comparisonFields
  }
}

fragment comparisonFields on Character {
  name
  appearsIn
  friends {
    name
  }
}

// 结果
{
  "data": {
    "leftComparison": {
      "name": "Luke Skywalker",
      "appearsIn": [
        "NEWHOPE",
        "EMPIRE",
        "JEDI"
      ],
      "friends": [
        {
          "name": "Han Solo"
        },
        {
          "name": "Leia Organa"
        },
        {
          "name": "C-3PO"
        },
        {
          "name": "R2-D2"
        }
      ]
    },
    "rightComparison": {
      "name": "R2-D2",
      "appearsIn": [
        "NEWHOPE",
        "EMPIRE",
        "JEDI"
      ],
      "friends": [
        {
          "name": "Luke Skywalker"
        },
        {
          "name": "Han Solo"
        },
        {
          "name": "Leia Organa"
        }
      ]
    }
  }

操作

一个操作query HeroNameAndFriends

  • 操作类型关键字——描述打算做什么类型的操作
    • query
    • mutation
    • subscription
  • 操作名称HeroNameAndFriends
    • 想象成函数名,有利于追踪和调试

变量(Variables)

  • 查询参数可能是动态的,GraphQL拥有一级方法将动态值提取到查询之外,然后作为分离的字典穿进去。这些动态值,就是变量
  • 如何使用变量
    • 使用$variableName替代查询中的静态值
    • 声明$variableName为查询接收的变量之一
    • variableName: value通过传输转用(通常是JSON)的分离的变量字典中。
  • 用法
// 声明
query HeroNameAndFriends($episode: Episode) {
  hero(episode: $episode) {
    name
    friends {
      name
    }
  }
}
// 查询
{
  "episode": "JEDI"
}
// 结果
{
  "data": {
    "hero": {
      "name": "R2-D2",
      "friends": [
        {
          "name": "Luke Skywalker"
        },
        {
          "name": "Han Solo"
        },
        {
          "name": "Leia Organa"
        }
      ]
    }
  }
}

变量使用注意事项

  • 变量前缀必须为$
  • 声明变量后跟类型,上例中是Episode
  • 所有声明的变量都必须是:
    • 标量
    • 枚举值
    • 输入对象类型(与服务器有关)
  • 要传递一个复杂对象到一个字段上,必须知道服务器上匹配的类型。
  • 变量定义允许:
    • 可选的
    • 必要的,在类型后加!

变量默认值

query HeroNameAndFriends($episode: Episode = "JEDI") {
  hero(episode: $episode) {
    name
    friends {
      name
    }
  }
}

指令(Directives)

  • 指令可以附着在字段或者片段包含的字段上,以服务单期待的方式改变查询的执行。
  • GraphQL核心规范的两个指令:
    • @include(if: Boolean)仅在参数为true,包含被指令附着的字段
    • @skip(if: Boolean)如果参数为true,跳过被指令附着的字段

变更(Mutations)

  • 用来变更服务器数据的方法
  • 建议导致写入的操作都应该显式的通过变更(mutation)来发送
  • 提价变更同时也可以查询变更后的对象。
// 声明变更
mutation CreateReviewForEpisode($ep: Episode!, $review: ReviewInput!) {
  createReview(episode: $ep, review: $review) {
    stars
    commentary
  }
}

// 操作
{
  "ep": "JEDI",
  "review": {
    "stars": 5,
    "commentary": "This is a great movie!"
  }
}

// 变更后查询结果
{
  "data": {
    "createReview": {
      "stars": 5,
      "commentary": "This is a great movie!"
    }
  }
}

变更中的多个字段

  • 查询字段,是并行查询
  • 变更字段,是线性执行,保证了变更不会出现 竞争的情况

内联片段(Inline Fragments)

  • GraphQL schema 具备自定义接口和联合类型的能力
  • 若查询的字段返回的是接口/联合类型,就需要内联片段来去处下层具体类型的数据
//声明
query HeroForEpisode($ep: Episode!) {
  hero(episode: $ep) {
    name
    ... on Droid {
      primaryFunction
    }
    ... on Human {
      height
    }
  }
}
// 操作
{
  "ep": "JEDI"
}
// 结果
{
  "data": {
    "hero": {
      "name": "R2-D2",
      "primaryFunction": "Astromech"
    }
  }
}

元字段(Meta fields)

  • GraphQL允许在查询的任何位置请求__typename,一个元字段,以获得那个位置的对象
// 声明
{
  search(text: "an") {
    __typename
    ... on Human {
      name
    }
    ... on Droid {
      name
    }
    ... on Starship {
      name
    }
  }
}

// 查询结果
{
  "data": {
    "search": [
      {
        "__typename": "Human",
        "name": "Han Solo"
      },
      {
        "__typename": "Human",
        "name": "Leia Organa"
      },
      {
        "__typename": "Starship",
        "name": "TIE Advanced x1"
      }
    ]
  }

相关文章

  • GraphQL学习——查询与变更

    简介 GraphQL是一个用于API的查询语言,一个使用基于类型系统来执行查询的服务端运行时 GraphQL未与任...

  • GraphQL学习-查询和变更

    你可以在本页学到有关如何查询 GraphQL 服务器的详细信息。 字段(Fields) 简单而言,GraphQL ...

  • Dgraph-查询语言

    查询语言 Dgraph的GraphQL+-是一种基于facebook的GraphQL的图查询语言。GraphQL并...

  • GraphQL与认证

    GraphQL与认证 很多人会问GraphQL怎么认证和授权。最终的答案是GraphQL只是一个查询语言和认证之类...

  • Graphql Go 基于Golang实践

    GraphQL GraphQL 既是一种用于 API 的查询语言也是一个满足你数据查询的运行时。 GraphQL ...

  • GraphQL学习-Schema 和类型

    类型系统(Type System) 如果你之前见到过 GraphQL 查询,你就知道 GraphQL 查询语言基本...

  • Graphql 架构和类型

    在此文章上面,您将了解有关GraphQL类型系统以及如何描述可查询数据的所有信息。由于GraphQL可以与任何后端...

  • Graphql集成SpringMVC和MongoDB

    什么是GraphQL GraphQL 是一种用于 API 的查询语言。 GraphQL 对你的 API 中的数据提...

  • GraphQL使用指南(开始)

    GraphQL使用指南(开始) Graphql 为查询而生,是一个由Facebook提出的应用层查询语言,所以我们...

  • GraphQL学习——执行

    一个GraphQL查询在被验证后,GraphQL服务器会将之执行。 一个例子 GraphQL工作原理:GraphQ...

网友评论

      本文标题:GraphQL学习——查询与变更

      本文链接:https://www.haomeiwen.com/subject/fpkswxtx.html