小试GraphQL

之前做的需求,基本都是REST风格,以github提供的api为例,比较二者差异。试用GraphQL,找寻其独到之处

REST

REST[1]

  • 一个URI代表一种资源
  • 通过HTTP动词对资源进行操作

以创建一个仓库[2]为例

GET[3],

PATCH[4]和 DELETE[5]类似


GraphQL

  • GraphQL的endpoint只有一个
  • 所有请求都是POST

可以在 Exploer[6]左边写查询,右边显示结果。

查询当前登录的用户名:

查询Go项目当前的star数:

GraphQL的endpoint只有一个,即

https://api.github.com/graphql

使用Postman:

使用querymutation来区分是查询还是修改

二者区别

  • REST一个URI就是一个资源,GraphQL只有一个URI
  • REST返回所有的内容,response体积较大,GraphQL可以只返回需要的数据,返回值体积小

GraphQL是一种语言,有自己的语法和类型系统

会有错误提示~

GraphQL的优势:

  • 取你所需要的数据,不多也不少

n+1问题[7]

  • nesting(嵌套查询)

比如想取一个pr的commits、comment、reviews,用REST需要请求四次,然后还需要对返回值进行组装;而用GraphQL则只需要一次请求,拿到的就是需要的数据

资源孤岛 (REST) vs Graph(GraphQL)

graphql-voyager[8]

  • 强类型(每一个GraphQL的请求发到服务端之后,服务端都会进行校验,不通过会报错)

Migrating from REST to GraphQL[9]


参考:

为什么GraphQL比REST好用?[10]

参考资料

1

REST: https://docs.github.com/en/rest

2

创建一个仓库: https://docs.github.com/en/rest/reference/repos#create-a-repository-for-the-authenticated-user

3

GET: https://docs.github.com/en/rest/reference/repos#get-a-repository

4

PATCH: https://docs.github.com/en/rest/reference/repos#update-a-repository

5

DELETE: https://docs.github.com/en/rest/reference/repos#delete-a-repository

6

Exploer: https://docs.github.com/en/graphql/overview/explorer

7

n+1问题: https://segmentfault.com/a/1190000039421843

8

graphql-voyager: https://apis.guru/graphql-voyager/

9

Migrating from REST to GraphQL: https://docs.github.com/en/graphql/guides/migrating-from-rest-to-graphql

10

为什么GraphQL比REST好用?: https://www.bilibili.com/video/BV1f4411A7qA

本文由mdnice多平台发布

相关推荐
BingoGo35 分钟前
Laravel13 + Vue3 的免费可商用 PHP 管理后台 CatchAdmin V5.2.0 发布
后端·php·laravel
rannn_1111 小时前
【Redis|高级篇1】分布式缓存|持久化(RDB、AOF)、主从集群、哨兵、分片集群
java·redis·分布式·后端·缓存
weixin_408099671 小时前
【实战教程】EasyClick 调用 OCR 文字识别 API(自动识别屏幕文字 + 完整示例代码)
前端·人工智能·后端·ocr·api·安卓·easyclick
添尹1 小时前
Go语言基础之指针
开发语言·后端·golang
GreenTea10 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
我是大猴子12 小时前
Spring代理类为何依赖注入失效?
java·后端·spring
码事漫谈12 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
码农BookSea13 小时前
ReAct:让大模型学会边想边做
后端·ai编程
码农BookSea14 小时前
10分钟掌握 JSON-RPC 协议,面试加分、设计不踩坑
后端
凤年徐14 小时前
C++手撕红黑树:从0到200行,拿下STL map底层核心
c++·后端·算法