加入收藏

GraphQL全解析,你学会了吗?

2023-06-28 09:11:04 来源:Java学研大本营

您可能已经看过很多关于GraphQL的内容,在这个过程中是不是有时会感到困惑和不知所措。本文让我尝试用更简单易懂的语言回答关于GraphQL的三个主要问题:GraphQL是什么,如何工作,何时使用?希望对您更好地理解GraphQL有所裨益。

1 什么是GraphQL

“Graph”指的是数据以类似图形的结构表示和连接。在GraphQL中,数据表示为具有节点和边的图形,允许不同数据实体之间的灵活关系。

“QL”代表“查询语言”,因为GraphQL提供了一种精确和可控的查询或请求数据的语言。


(资料图片仅供参考)

示例:书和作者的关系可以用图来表示,可以很容易地使用GraphQL进行查询:

深入研究GraphQL,我们发现它是:

类型系统:定义数据的外观以及事物之间的关系。类型系统定义各种数据类型和架构,这是客户端和服务器之间的合同。查询语言:查询数据的语言,它知道从哪里获取数据并包含验证或执行查询的规则。

简而言之,GraphQL能让客户端精确指定它需要从API获取的数据。

Facebook在2012年开始开发GraphQL,并于2015年将其发布为开源。2018年,GraphQL被移至新成立的GraphQL基金会,由非营利组织Linux基金会托管。

GraphQL支持读取、写入(变异)和订阅数据的更改,让我们可以实时更新。

2 GraphQL如何工作

GraphQL有两个部分:请求数据的客户端和提供数据的服务器,以下是解释其工作原理的步骤:

i)定义模式:服务器定义GraphQL模式,这类似于描述可用数据和操作的蓝图。例如,如果我们有一个带有字段(id、name和pageCount)的Book实体,并且有一个查询是按id查询书籍,则其模式将如下所示:

type Query {    bookById(id: ID): Book}type Book {    id: ID    name: String    pageCount: Int}

ii)发送查询:客户端向服务器发送GraphQL查询,指定所需数据和所需结构。

query bookDetails {  bookById(id: "book-1") {    id    name    pageCount  }}

iii)解决查询:服务器的GraphQL引擎接收查询并开始解决查询。它根据查询确定需要哪些数据,以及应执行哪些解析器函数来获取该数据。

iv)获取数据:解析器函数根据查询要求从各种数据源(例如数据库、API)检索数据。

v)组装响应:GraphQL引擎收集检索到的数据,并按客户端请求的格式组装响应。它仅包括查询中请求的确切数据字段,减少不必要的数据传输。

vi)返回响应:服务器将响应发送回客户端,提供查询中精确请求的数据。

3 何时可以使用GraphQL

GraphQL适用于处理复杂或经常变化的数据需求,因为它可以将数据请求的控制权交给客户端,让客户端在任何时间请求任何数据。这让在每次API变更迭代或从这些API请求的数据发生变化时更容易进行更新。与REST API相比,GraphQL允许客户端精确指定所需数据的结构和字段,从而避免了获取过度或获取不足的问题。因此,GraphQL可以提高数据传输的精确性和效率,使应用程序更加灵活和可扩展。

如果应用程序需要从多个来源聚合数据,GraphQL可以帮助把这些来源统一到单个API中。它提供了一个抽象层,可从各种服务中获取和组合数据,使数据的获取和整合更加简单和高效。

当应用程序需要实时更新和订阅时,GraphQL提供内置功能。这些功能允许客户端订阅特定数据的变化,并在数据更改时实时推送通知,从而提高应用程序的实时性和响应性。

总之,如果您需要更好地控制和定制API响应,并希望有效地处理复杂或不断变化的数据需求,那么GraphQL是一个非常有用的工具。

4 使用Spring实现GraphQL

随着spring-boot-starter-graphql框架的到来,使用Spring实现GraphQL变得更加容易。

在Spring项目中集成GraphQL的步骤如下:

i)向项目添加gradle/maven graphql starter依赖:

//Gradleimplementation "org.springframework.boot:spring-boot-starter-graphql"//Maven    org.springframework.boot    spring-boot-starter-graphql

ii)创建一个目录src/main/resources/graphql,并在该目录下添加一个名为schema.graphqls的文件,包含以下内容:

type Query {    bookById(id: ID): Book}type Book {    id: ID    name: String    pageCount: Int}

在这里,我们创建了一个Book的schema。每个schema都有一个顶级查询类型,这里的schema定义了一个名为bookById的查询,用于返回特定书籍的详细信息。

iii)GraphQL服务器中的每个复杂类型都由Java bean表示,并且Java bean中的字段将直接映射到GraphQL响应中的字段,其名称基于字段名称。

public record Book (String id, String name, int pageCount) {    private static List books = Arrays.asList(            new Book("book-1", "Effective Java", 416),            new Book("book-2", "Hitchhiker"s Guide to the Galaxy", 208),            new Book("book-3", "Down Under", 436)    );    public static Book getById(String id) {        return books.stream()    .filter(book -> book.id().equals(id))    .findFirst()    .orElse(null);    }}

iv) Spring的GraphQL提供了基于注解的编程模型。通过控制器注释方法,我们可以声明如何获取特定GraphQL字段的数据。现在让我们添加BookController.java

@Controllerpublic class BookController {    @QueryMapping    public Book bookById(@Argument String id) {        return Book.getById(id);    }}

通过定义一个名为bookById的方法并用@QuerMapping注释,此控制器声明了如何获取Query类型下定义的Book。查询字段从方法名称确定,但也可以在注释本身上声明。

v) Spring的GraphQL还为我们提供了一个用于编写和执行查询的可视界面,名为GraphiQL。通过将以下配置添加到application.yaml文件中启用GraphiQL:

spring  graphql    graphiql      enabled: true

启动Spring应用程序并导航到http://localhost:8080/graphiql.

vi)在窗口顶部键入查询并单击播放按钮。

query bookDetails {  bookById(id: "book-1") {    id    name    pageCount  }}

您将看到以下响应:

这样您已经构建了一个GraphQL服务并成功查询了数据!您的数据之旅从此开始!快动手试试吧~

关键词:

相关新闻

资讯

全新内饰,豪华座椅包加持!2024款传祺GS8配置曝光!
全新内饰,豪华座椅包加持!2024款传祺GS8配置曝光!

在20万级的家用市场,能站稳脚跟的中国品牌产品并不多......更多>

河南大学领导到通许县竖岗镇调研指导
河南大学领导到通许县竖岗镇调研指导

6月17日,河南大学国内合作办公室主任、河南戏剧学院......更多>

河南大学领导到通许县竖岗镇调研指导乡村振兴工作
河南大学领导到通许县竖岗镇调研指导乡村振兴工作

6月2日,河南大学国内合作办公室副主任刘会宾带领调研......更多>

河南省交通事业发展中心领导到通许县竖岗镇调研“三夏”生产工作
河南省交通事业发展中心领导到通许县竖岗镇调研“三夏”生产工作

6月2日下午,河南省交通事业发展中心工程建设处副处长......更多>

速递!菲利华(300395.SZ):实控人邓家贵减持期届满 已减持40.28万股
速递!菲利华(300395.SZ):实控人邓家贵减持期届满 已减持40.28万股

格隆汇6月27日丨菲利华300395300395SZ公布截至公告日......更多>

中国贵酒集团董事长韩宏伟受邀参加2023天津夏季达沃斯论坛
中国贵酒集团董事长韩宏伟受邀参加2023天津夏季达沃斯论坛

6月27日上午,世界经济论坛第十四届新领军者年会暨202......更多>

【天天聚看点】重磅!湖南出台入境旅游奖励办法
【天天聚看点】重磅!湖南出台入境旅游奖励办法

近日,为推进入湘旅游高质量发展,促进入境旅游市场稳......更多>

2023粤港澳车展:911 GT3 RS实车首次公众亮相_焦点滚动
2023粤港澳车展:911 GT3 RS实车首次公众亮相_焦点滚动

在2023粤港澳车展上,保时捷911GT3RS实车首次公众亮相......更多>

他年赚56亿花20亿泡妞,家中养百位美女,晚年却给儿子留26亿巨债
他年赚56亿花20亿泡妞,家中养百位美女,晚年却给儿子留26亿巨债

“只要是我想得到的女人,就没有得不到的!”这句话出......更多>

大连市应急局:值守不放松 坚守岗位保平安
大连市应急局:值守不放松 坚守岗位保平安

央广网大连6月26日消息(记者王松)为贯彻落实国家、......更多>

关注

环球通讯!共青农场有限公司:“书记工程”掌舵 助力企业“远航”
环球通讯!共青农场有限公司:“书记工程”掌舵 助力企业“远航”
???自“书记工程”实施以来,共青农场有限公司以习... 更多>
环球通讯!共青农场有限公司:“书记工程”掌舵 助力企业“远航”
???自“书记工程”实施以来,共青农场有限公司以习... 更多>
16号线一期、地铁2号线二期开通 西安地铁运营里程突破300公里_世界讯息
6月27日上午11时,备受广大市民关心的西安地铁16号线... 更多>
银行工作人员透露:聪明人从不选择大额存款,有这3个致命弊端
银行工作人员透露:聪明人从不选择大额存款,有这3个... 更多>
富国银行荐股两只,涨幅将达125%?-独家焦点
富国银行看好以下两只美股。 更多>
禁毒主题宣传进校园,守护青少年健康成长_世界播报
为进一步营造全民禁毒社会氛围,共同守护青少年健康,... 更多>
女子遭遇投资骗局,民警面对面止损|世界时快讯
扬子晚报网6月27日讯(记者郭一鹏通讯员 雨公宣杨汉... 更多>
【全球聚看点】世界互联网大会数字文明尼山对话在山东举行
消息(新闻联播):今天(6月26日),世界互联网大会... 更多>
瞄准前沿技术 促进降本增效(经济聚焦)_天天即时
核心阅读从上游硅料技术研发、中游组件生产制造,到下... 更多>
朱啸虎、傅盛激辨GPT背后,AI 大模型“泡沫”要破了?
ChatGPT热潮下,基于大模型的创业是否有价值,猎豹移... 更多>
英国连锁超市Sainsbury进一步降价 表明通胀有所缓解
【英国连锁超市Sainsbury进一步降价表明通胀有所缓解... 更多>
焦点日报:《合金装备4》曾计划登陆Xbox 360 主机遭取消
《合金装备4》曾考虑登录Xbox360主机,但由于需要多张... 更多>
端午节假期国内出游人次破亿
端午节假期,旅游市场表现亮眼。文旅部6月24日晚披露... 更多>