今日視點(diǎn):GraphQL全解析,你學(xué)會(huì)了嗎?
您可能已經(jīng)看過(guò)很多關(guān)于GraphQL的內(nèi)容,在這個(gè)過(guò)程中是不是有時(shí)會(huì)感到困惑和不知所措。本文讓我嘗試用更簡(jiǎn)單易懂的語(yǔ)言回答關(guān)于GraphQL的三個(gè)主要問(wèn)題:GraphQL是什么,如何工作,何時(shí)使用?希望對(duì)您更好地理解GraphQL有所裨益。
1 什么是GraphQL“Graph”指的是數(shù)據(jù)以類似圖形的結(jié)構(gòu)表示和連接。在GraphQL中,數(shù)據(jù)表示為具有節(jié)點(diǎn)和邊的圖形,允許不同數(shù)據(jù)實(shí)體之間的靈活關(guān)系。
“QL”代表“查詢語(yǔ)言”,因?yàn)镚raphQL提供了一種精確和可控的查詢或請(qǐng)求數(shù)據(jù)的語(yǔ)言。
(資料圖)
示例:書(shū)和作者的關(guān)系可以用圖來(lái)表示,可以很容易地使用GraphQL進(jìn)行查詢:
深入研究GraphQL,我們發(fā)現(xiàn)它是:
類型系統(tǒng):定義數(shù)據(jù)的外觀以及事物之間的關(guān)系。類型系統(tǒng)定義各種數(shù)據(jù)類型和架構(gòu),這是客戶端和服務(wù)器之間的合同。查詢語(yǔ)言:查詢數(shù)據(jù)的語(yǔ)言,它知道從哪里獲取數(shù)據(jù)并包含驗(yàn)證或執(zhí)行查詢的規(guī)則。簡(jiǎn)而言之,GraphQL能讓客戶端精確指定它需要從API獲取的數(shù)據(jù)。
Facebook在2012年開(kāi)始開(kāi)發(fā)GraphQL,并于2015年將其發(fā)布為開(kāi)源。2018年,GraphQL被移至新成立的GraphQL基金會(huì),由非營(yíng)利組織Linux基金會(huì)托管。
GraphQL支持讀取、寫(xiě)入(變異)和訂閱數(shù)據(jù)的更改,讓我們可以實(shí)時(shí)更新。
2 GraphQL如何工作GraphQL有兩個(gè)部分:請(qǐng)求數(shù)據(jù)的客戶端和提供數(shù)據(jù)的服務(wù)器,以下是解釋其工作原理的步驟:
i)定義模式:服務(wù)器定義GraphQL模式,這類似于描述可用數(shù)據(jù)和操作的藍(lán)圖。例如,如果我們有一個(gè)帶有字段(id、name和pageCount)的Book實(shí)體,并且有一個(gè)查詢是按id查詢書(shū)籍,則其模式將如下所示:
type Query { bookById(id: ID): Book}type Book { id: ID name: String pageCount: Int}
ii)發(fā)送查詢:客戶端向服務(wù)器發(fā)送GraphQL查詢,指定所需數(shù)據(jù)和所需結(jié)構(gòu)。
query bookDetails { bookById(id: "book-1") { id name pageCount }}
iii)解決查詢:服務(wù)器的GraphQL引擎接收查詢并開(kāi)始解決查詢。它根據(jù)查詢確定需要哪些數(shù)據(jù),以及應(yīng)執(zhí)行哪些解析器函數(shù)來(lái)獲取該數(shù)據(jù)。
iv)獲取數(shù)據(jù):解析器函數(shù)根據(jù)查詢要求從各種數(shù)據(jù)源(例如數(shù)據(jù)庫(kù)、API)檢索數(shù)據(jù)。
v)組裝響應(yīng):GraphQL引擎收集檢索到的數(shù)據(jù),并按客戶端請(qǐng)求的格式組裝響應(yīng)。它僅包括查詢中請(qǐng)求的確切數(shù)據(jù)字段,減少不必要的數(shù)據(jù)傳輸。
vi)返回響應(yīng):服務(wù)器將響應(yīng)發(fā)送回客戶端,提供查詢中精確請(qǐng)求的數(shù)據(jù)。
3 何時(shí)可以使用GraphQLGraphQL適用于處理復(fù)雜或經(jīng)常變化的數(shù)據(jù)需求,因?yàn)樗梢詫?shù)據(jù)請(qǐng)求的控制權(quán)交給客戶端,讓客戶端在任何時(shí)間請(qǐng)求任何數(shù)據(jù)。這讓在每次API變更迭代或從這些API請(qǐng)求的數(shù)據(jù)發(fā)生變化時(shí)更容易進(jìn)行更新。與REST API相比,GraphQL允許客戶端精確指定所需數(shù)據(jù)的結(jié)構(gòu)和字段,從而避免了獲取過(guò)度或獲取不足的問(wèn)題。因此,GraphQL可以提高數(shù)據(jù)傳輸?shù)木_性和效率,使應(yīng)用程序更加靈活和可擴(kuò)展。
如果應(yīng)用程序需要從多個(gè)來(lái)源聚合數(shù)據(jù),GraphQL可以幫助把這些來(lái)源統(tǒng)一到單個(gè)API中。它提供了一個(gè)抽象層,可從各種服務(wù)中獲取和組合數(shù)據(jù),使數(shù)據(jù)的獲取和整合更加簡(jiǎn)單和高效。
當(dāng)應(yīng)用程序需要實(shí)時(shí)更新和訂閱時(shí),GraphQL提供內(nèi)置功能。這些功能允許客戶端訂閱特定數(shù)據(jù)的變化,并在數(shù)據(jù)更改時(shí)實(shí)時(shí)推送通知,從而提高應(yīng)用程序的實(shí)時(shí)性和響應(yīng)性。
總之,如果您需要更好地控制和定制API響應(yīng),并希望有效地處理復(fù)雜或不斷變化的數(shù)據(jù)需求,那么GraphQL是一個(gè)非常有用的工具。
4 使用Spring實(shí)現(xiàn)GraphQL隨著spring-boot-starter-graphql框架的到來(lái),使用Spring實(shí)現(xiàn)GraphQL變得更加容易。
在Spring項(xiàng)目中集成GraphQL的步驟如下:
i)向項(xiàng)目添加gradle/maven graphql starter依賴:
//Gradleimplementation "org.springframework.boot:spring-boot-starter-graphql"http://Maven org.springframework.boot spring-boot-starter-graphql
ii)創(chuàng)建一個(gè)目錄src/main/resources/graphql,并在該目錄下添加一個(gè)名為schema.graphqls的文件,包含以下內(nèi)容:
type Query { bookById(id: ID): Book}type Book { id: ID name: String pageCount: Int}
在這里,我們創(chuàng)建了一個(gè)Book的schema。每個(gè)schema都有一個(gè)頂級(jí)查詢類型,這里的schema定義了一個(gè)名為bookById的查詢,用于返回特定書(shū)籍的詳細(xì)信息。
iii)GraphQL服務(wù)器中的每個(gè)復(fù)雜類型都由Java bean表示,并且Java bean中的字段將直接映射到GraphQL響應(yīng)中的字段,其名稱基于字段名稱。
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提供了基于注解的編程模型。通過(guò)控制器注釋方法,我們可以聲明如何獲取特定GraphQL字段的數(shù)據(jù)。現(xiàn)在讓我們添加BookController.java
@Controllerpublic class BookController { @QueryMapping public Book bookById(@Argument String id) { return Book.getById(id); }}
通過(guò)定義一個(gè)名為bookById的方法并用@QuerMapping注釋,此控制器聲明了如何獲取Query類型下定義的Book。查詢字段從方法名稱確定,但也可以在注釋本身上聲明。
v) Spring的GraphQL還為我們提供了一個(gè)用于編寫(xiě)和執(zhí)行查詢的可視界面,名為GraphiQL。通過(guò)將以下配置添加到application.yaml文件中啟用GraphiQL:
spring graphql graphiql enabled: true
啟動(dòng)Spring應(yīng)用程序并導(dǎo)航到http://localhost:8080/graphiql.
vi)在窗口頂部鍵入查詢并單擊播放按鈕。
query bookDetails { bookById(id: "book-1") { id name pageCount }}
您將看到以下響應(yīng):
這樣您已經(jīng)構(gòu)建了一個(gè)GraphQL服務(wù)并成功查詢了數(shù)據(jù)!您的數(shù)據(jù)之旅從此開(kāi)始!快動(dòng)手試試吧~
關(guān)鍵詞:
您可能也感興趣:
- 今日視點(diǎn):GraphQL全解析,你學(xué)會(huì)了嗎?
- 時(shí)空邊際兌換碼最新2023(微信10個(gè)禮包...
- 中信建投證券:氫能板塊進(jìn)入明確投資窗口期
- 全球最新:空調(diào)自動(dòng)關(guān)機(jī)怎么辦(空調(diào)自...
- 調(diào)貶261個(gè)基點(diǎn),人民幣兌美元中間價(jià)報(bào)7.2056
- 全球今日訊!學(xué)習(xí)家風(fēng)家教心得體會(huì)(家...
- 2023年四川榮縣高考取得新突破_焦點(diǎn)報(bào)道
- 華為手機(jī)來(lái)電秀怎么設(shè)置_來(lái)電秀怎么設(shè)置
今日熱點(diǎn)
為您推薦
時(shí)空邊際兌換碼最新2023(微信10個(gè)禮包碼領(lǐng)?。?世界今頭條
中信建投證券:氫能板塊進(jìn)入明確投資窗口期
全球最新:空調(diào)自動(dòng)關(guān)機(jī)怎么辦(空調(diào)自動(dòng)關(guān)機(jī))
更多
- 昌平這處國(guó)有住宅房屋協(xié)議搬遷啟動(dòng)|天天熱文
- 世界熱訊:溫氏股份:子公司擬3.5億元增資同茂定增2號(hào)基金
- 著名媒體人胡錫進(jìn):已開(kāi)一個(gè)股票賬戶 正式進(jìn)入中國(guó)股市
- 新動(dòng)態(tài):森源電氣:入圍江蘇石油充電機(jī)招標(biāo)項(xiàng)目
- 【全球快播報(bào)】家居周十條丨中國(guó)住博會(huì)舉辦、線上“宜家”上...
- 搜神傳演員表人物圖片(搜神傳演員表) 新動(dòng)態(tài)
- 2023年6月25日雙子座運(yùn)勢(shì),雙子座今日運(yùn)勢(shì)_全球新消息
- 《小美人魚(yú)》全球票房破5億美元 黑美人魚(yú)你們愛(ài)嗎?-焦點(diǎn)速遞
更多
- 楊函數(shù)(楊函數(shù)1分視頻
- 世界球精選!業(yè)內(nèi):化纖紡織市場(chǎng)開(kāi)工率均不足八成
- 2023年全國(guó)節(jié)能宣傳周和全國(guó)低碳日活動(dòng)將于7月10日至16日開(kāi)展
- 增程版價(jià)格下探至14.99萬(wàn)元,深藍(lán)S7 6月30日全國(guó)交付 觀點(diǎn)
- 雅居樂(lè)集團(tuán)(03383):彭說(shuō)龍獲委任為獨(dú)立非執(zhí)行董事_世界觀速訊
- 臨沂兩級(jí)法院突出打擊重點(diǎn) 毒品犯罪寬嚴(yán)相濟(jì) 世界今日?qǐng)?bào)
- dns改成114.114.114有危險(xiǎn)嗎(dns服務(wù)器可能不可用) 天天快消息
- 懷古詩(shī)的標(biāo)題有哪些 高中語(yǔ)文古詩(shī)詞必備知識(shí)點(diǎn)?
排行
- 調(diào)貶261個(gè)基點(diǎn),人民幣兌美元中間價(jià)報(bào)7.2056
- 豐富普惠保險(xiǎn)產(chǎn)品業(yè)務(wù),探索面向小微企業(yè)的保單融資產(chǎn)品
- 慧擇一季度總營(yíng)收7.3億元,同比增長(zhǎng)195.5%
- 數(shù)字化正改變壽險(xiǎn)和非壽險(xiǎn)公司的銷售和服務(wù)
- 水滴保上半年平均理賠時(shí)效縮短至15.7小時(shí)
- 內(nèi)蒙古將開(kāi)展草原保險(xiǎn)試點(diǎn),面積達(dá)3797.88萬(wàn)畝
- 三孩政策放開(kāi),適合孕期的保險(xiǎn)該如何買?
- 北京普惠健康保參保人數(shù)破百萬(wàn),打工族醫(yī)療保障需求旺盛
- 中國(guó)太保,前四月保費(fèi)收入1630.66億元
- 《醫(yī)療保障法(征求意見(jiàn)稿)》明確要鼓勵(lì)發(fā)展商業(yè)健康保險(xiǎn)
最近更新
- 今日視點(diǎn):GraphQL全解析,你學(xué)會(huì)了嗎?
- 環(huán)球頭條:清潔工嫌聲音太吵關(guān)掉實(shí)驗(yàn)室超低溫冰箱電源,導(dǎo)致2...
- 知名地產(chǎn)巨頭確認(rèn)違約
- 「港股異動(dòng)」微創(chuàng)機(jī)器人-B(02252.HK)漲10.38%
- 世界熱推薦:【高質(zhì)量發(fā)展調(diào)研行】八閩“梧桐”繁茂 企業(yè)“...
- 知名財(cái)經(jīng)作家吳曉波微博被禁言 要聞
- 天天即時(shí)看!婚姻易失和的5生肖組合,生肖蛇與生肖雞把家變辯...
- 新疆打造“文化+美食+旅游”城市名片 多地開(kāi)啟“人從眾”模式
- 各地各部門通過(guò)多種形式不斷提高人民群眾識(shí)毒、防毒、拒毒意識(shí)
- 整套月租925元起!北京石景山公租房快速配租已啟動(dòng)
- 郎酒股份發(fā)布最新人事任命 高管隊(duì)伍呈專業(yè)化、知識(shí)化、年輕...
- 全球關(guān)注:重慶法院近五年審結(jié)毒品犯罪案件呈持續(xù)下降態(tài)勢(shì)
- 有一種母愛(ài)叫“再婚后”,大S為愛(ài)郎消費(fèi)千元,卻無(wú)暇顧及兒女
- 新產(chǎn)業(yè)(300832.SZ):取得1項(xiàng)發(fā)明專利證書(shū)-實(shí)時(shí)焦點(diǎn)
- 資訊:江蘇發(fā)布5月設(shè)區(qū)市降塵量排名 鎮(zhèn)江揚(yáng)州徐州降塵量較大
- 關(guān)于下發(fā)2023年普通高校在川招生計(jì)劃更正及調(diào)整的通知
- 長(zhǎng)沙25.06億成功出讓2宗限價(jià)地 保利、美的各拿1宗
- 新疆哈巴河縣的警察之家——樺城警苑正式啟用
- 世界最資訊丨豬肺怎樣做才好吃?
- 重磅!深圳積分入戶申報(bào)明日開(kāi)啟,詳情公布
- 中共中央紀(jì)委發(fā)布通知 規(guī)范和明確黨員受留黨察看處分期滿后...
- 每日熱點(diǎn):中國(guó)開(kāi)源,邁入“新生代” | 「鈦度號(hào)」作品周榜第60期
- 海南禁毒工作取得“四降四升兩深入”歷史性成效
- 華亭蓮花臺(tái)發(fā)現(xiàn)國(guó)家二級(jí)保護(hù)稀有動(dòng)物“神獸”——中華鬣羚
- 微軟稱完成其量子超算路線圖第一個(gè)里程碑
- gamerant盤點(diǎn)《FF16》未登場(chǎng)怪物 奪心魔、仙人刺等
- 《星之海洋:第二個(gè)故事R》中文世界觀介紹影像公布
- 天天新消息丨工信部已認(rèn)定“專精特新”中小企業(yè)超8萬(wàn)家 將實(shí)...
- 長(zhǎng)沙車站南路社區(qū):緊繃燃?xì)獍踩?,加?qiáng)網(wǎng)格巡查力度 前沿資訊
- 最資訊丨河北唐山:投礁種草修復(fù)渤海生態(tài) “海底沙漠”現(xiàn)“...
今日要聞
- 2023年6月26日山東省磷酸價(jià)格最新行情預(yù)測(cè)
- 全球關(guān)注:重慶法院近五年審結(jié)毒品犯罪案件呈持續(xù)下降態(tài)勢(shì)
- 突發(fā)!1人死亡!蘭州、新疆化工巨頭接連發(fā)生閃爆事故!附視頻!
- 全省法院對(duì)18宗毒品犯罪案件集中公開(kāi)宣判
- 合資品牌巨虧近20億 廣汽集團(tuán)欲再“輸血”引投資者擔(dān)憂-世界時(shí)快訊
- 熱點(diǎn)聚焦:A股市場(chǎng)大幅跳空低開(kāi)弱勢(shì)震蕩收跌:三大股指均跌逾1%,兩市近4200股收跌
- 局域網(wǎng) 城域網(wǎng) 廣域網(wǎng)的區(qū)別(局域網(wǎng)城域網(wǎng)廣域網(wǎng)的傳輸速率)
- 昌平這處國(guó)有住宅房屋協(xié)議搬遷啟動(dòng)|天天熱文
- 當(dāng)前熱議!廣州中小學(xué)寒暑假時(shí)間公布,高三學(xué)生8月1日開(kāi)學(xué)
- 郵政個(gè)人先進(jìn)事跡范文大全_郵政個(gè)人先進(jìn)事跡范文