小试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多平台发布

相关推荐
掘金者阿豪3 分钟前
🚀 CentOS Stream 9服务器Docker部署KWDB:从零到跨模查询实战全记录
后端
yang_xin_yu9 分钟前
一文带你精通泛型PECS原则与四大核心函数式接口
后端
孟陬19 分钟前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
树獭叔叔19 分钟前
13-KV Cache与位置编码表:大模型推理加速的核心技术
后端·aigc·openai
想用offer打牌22 分钟前
一站式了解四种限流算法
java·后端·go
嘻哈baby22 分钟前
用 C++ 写线程池是怎样一种体验?
后端
嘻哈baby26 分钟前
SQL Server 和 Oracle 以及 MySQL 有哪些区别?
后端
绝无仅有26 分钟前
Redis过期删除与内存淘汰策略详解
后端·面试·架构
武子康30 分钟前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
绝无仅有35 分钟前
Redis大Key问题排查与解决方案全解析
后端·面试·架构