Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
[FRONT IN VALE - 2019] - INTRODUÇÃO AO MARAVIL...
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Kamila de fatima santos oliveira
August 10, 2019
Programming
1
120
[FRONT IN VALE - 2019] - INTRODUÇÃO AO MARAVILHOSO MUNDO DO GRAPHQL
Kamila de fatima santos oliveira
August 10, 2019
Tweet
Share
More Decks by Kamila de fatima santos oliveira
See All by Kamila de fatima santos oliveira
Tirando sua startup do papel com github spark + github copilot
kamilahsantos
0
26
De java para Kotlin: Como aprender e liderar times nessa linguagem
kamilahsantos
0
45
Quarkus-Club-criando-arquiteturas-escalaveis-na-pratica
kamilahsantos
1
55
System design 101 - Java day Noroeste
kamilahsantos
2
110
[Thasfin + Orange Juice na CPBR] Minha aplicação virou um monstrinho e agora ?
kamilahsantos
1
88
Minha aplicação virou um monstrinho e agora?
kamilahsantos
2
130
Spring + Localstack : usando aws de forma gratuita
kamilahsantos
2
260
Hacktoberfest DevsJavaGirl
kamilahsantos
0
140
[We are developers Java developer day ] - I will have to refactor ! And now ? Refactoring Techniques in Java
kamilahsantos
1
140
Other Decks in Programming
See All in Programming
ふつうの Rubyist、ちいさなデバイス、大きな一年
bash0c7
0
1.1k
どんと来い、データベース信頼性エンジニアリング / Introduction to DBRE
nnaka2992
1
310
[PHPerKaigi 2026]PHPerKaigi2025の企画CodeGolfが最高すぎて社内で内製して半年運営して得た内製と運営の知見
ikezoemakoto
0
220
SourceGeneratorのマーカー属性問題について
htkym
0
200
車輪の再発明をしよう!PHP で実装して学ぶ、Web サーバーの仕組みと HTTP の正体
h1r0
2
200
ベクトル検索のフィルタを用いた機械学習モデルとの統合 / python-meetup-fukuoka-06-vector-attr
monochromegane
2
490
The Past, Present, and Future of Enterprise Java
ivargrimstad
0
830
GC言語のWasm化とComponent Modelサポートの実践と課題 - Scalaの場合
tanishiking
0
120
それはエンジニアリングの糧である:AI開発のためにAIのOSSを開発する現場より / It serves as fuel for engineering: insights from the field of developing open-source AI for AI development.
nrslib
1
380
20260315 AWSなんもわからん🥲
chiilog
2
160
ポーリング処理廃止によるイベント駆動アーキテクチャへの移行
seitarof
3
1.1k
RAGでハマりがちな"Excelの罠"を、データの構造化で突破する
harumiweb
9
2.9k
Featured
See All Featured
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
200
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.8k
My Coaching Mixtape
mlcsv
0
79
Marketing to machines
jonoalderson
1
5k
Making the Leap to Tech Lead
cromwellryan
135
9.8k
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
220
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
0
240
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
180
Producing Creativity
orderedlist
PRO
348
40k
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
130
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
480
エンジニアに許された特別な時間の終わり
watany
106
240k
Transcript
Maravilhoso mundo do Graphql INTRODUÇÃO AO
@kamila_code kamilahsantos /kamila-santos-oliveira @kamilah_santos Kamila Santos, 21 anos Developer @devsjavagirl
Quem é esse tal de Graphql Linguagem de consulta baseada
em grafos, criada pelo Facebook em 2012
Quem é esse tal de Graphql O retorno dos dados
é totalmente previsível, e tornou open-source em 2015.
Quem usa Graphql?
É tipo Rest? NÃO
É tipo Rest? Em Rest, ao realizar buscas, temos vários
endpoints, no GraphQl só temos um endpoint para acessar os dados do servidor
É tipo Rest? Em Rest temos estrutura de dados fixa,
o que faz com que sempre traga mais dados do que o necessário
É tipo Rest? No Graphql trazemos exatamente o que precisamos
da nossa API através da construção de queries.
Como funciona?
Como funciona? Query language, server-side runtime para execução dessas queries
a partir da definição de schema (tipagem)
Como funciona? Não está vinculado a nenhum banco de dados
específico ou mecanismo de armazenamento.
Como funciona? Um service é criado definindo types e fields
e depois criando funções para cada type e cada field
Como funciona?
Como funciona?
Queries? Com o seu service em execução, podemos enviar queries
para serem validadas e executadas.
Queries? Um query é recebida e verificada para que somente
retorne os types e fields informados na query e depois é executada
Queries?
Queries?
Fields? As queries solicitam fields específicos em objetos .
Fields?
Fields? As queries em Graphql permitem percorrer objetos relacionados e
seus campos em uma única solicitação
Fields?
Fields?
Arguments? Além de atravessar pelos objetos e campos podemos passar
argumentos na busca desses dados
Arguments?
Arguments?
Arguments? Podemos passar argumentos para campos escalares, para fazer conversões
de dados no server em vez de cada client individualmente.
Arguments?
Arguments?
Aliases Os fields do objeto do resultado correspondem ao nome
do campo na consulta, não seria possível consultar diretamente o mesmo campo com argumentos diferentes.
Aliases Para resolver isto, podemos criar aliases, para renomear o
resultado do campo para algo mais descritivo que deseje.
Aliases
Aliases
Fragments Imagine uma situação que você tem duas pessoas e
quer exibi-las lado a lado junto com seus amigos, precisaríamos repetir os campos um para cada lado da comparação?
Fragments NÃO. Com os fragments podemos construir conjuntos de campos
e inclui-los nas consultas necessárias
Fragments
Fragments
Fragments
Fragments A ideia dos fragments é recomendada em situações em
que precisamos dividir os requisitos de dados do aplicativo em parte menores, quando precisa combinar componentes da UI com vários fragments diferentes numa busca inicial.
Usando variables em fragments Temos a possibilidade de usar variáveis
nos fragments das nossas consultas
Usando variables em fragments
Usando variables em fragments
Usando variables em fragments
Variáveis Para argumentos dinâmicos, o client pode precisar manipular os
arquivos em runtime e seriariza-la em formato em Graphql.
Variáveis O Graphql vai pegar esses dados e passar como
um dicionário separado.
Variáveis Substitua o valor estático na consulta por $variableName
Variáveis Declarar $variableNamecomo uma das variáveis aceitas pela consulta
Variáveis Passe variableName: value no dicionário de variáveis separado, específico
do transporte (geralmente JSON)
Variáveis
Variáveis
Directives Podem ser anexadas a um field ou inclusão de
fragment, podendo alterar a execução da consulta da forma que o servidor desejar
Directives @include(if: Boolean) Inclui somente se o resultado do campo
é true @skip(if: Boolean) pula o argumento se o elemento for true
Directives
Directives
Directives
Mutations? Da mesma forma que as Queries, nas Mutations podemos
passar campos aninhados
Mutations?
Mutations?
Mutations?
Schemas and Types
Schemas and Types
Interfaces Abstrai um conjunto de campos para serem implementados
Interfaces
Interfaces
Interfaces
Servers Clients
Referências https://graphql.org/learn https://graphql.org/code/#server-libraries https://graphql.org/code/#graphql-clients https://tableless.com.br/graphql-a-nova-era-d as-apis-web/
Referências https://speakerdeck.com/ketemartinsrufino/gr aphql-para-reduzir-complexidade-no-front-e-n o-back https://www.slideshare.net/PaulaSantana12?ut m_campaign=profiletracking&utm_medium=ss site&utm_source=ssslideview
Referências https://medium.com/idexo-developers/graphql -e-rest-quais-as-diferen%C3%A7as-99cae22871 a7 https://www.apollographql.com/ https://relay.dev/
Referências https://www.graph.cool/ https://hasura.io/
Obrigada <3