Skip to content

Commit

Permalink
Link to persisted queries in tutorial (#4359)
Browse files Browse the repository at this point in the history
Summary:
Use correct name and add link to Persisted queries

Pull Request resolved: #4359

Reviewed By: voideanvalue

Differential Revision: D47554784

Pulled By: captbaritone

fbshipit-source-id: 982197366d9b61392c8817d9fae583e774d97158
  • Loading branch information
robinpokorny authored and facebook-github-bot committed Aug 9, 2023
1 parent 5450fcd commit 007eff0
Showing 1 changed file with 1 addition and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -227,7 +227,7 @@ Relay will garbage-collect nodes from the Store if they aren’t “reachable”
<details>
<summary>Deep dive: Why GraphQL Needs a Syntax for Variables</summary>

You might be wondering why GraphQL even has the concept of variables, instead of just interpolating the value of the variables into the query string. Well, [as mentioned before](../queries-1), the text of the GraphQL query string isn’t available at runtime, because Relay replaces it with a data structure that is more efficient. You can also configure Relay to use *prepared queries*, where the compiler uploads each query to the server at build time and assigns it an ID — in that case, at runtime, Relay is just telling the server “Give me query #1337”, so string interpolation isn't possible and therefore the variables have to come out of band. Even when the query string is available, passing variable values separately eliminates any issues with serializing arbitrary values and escaping strings, above what is required with any HTTP request.
You might be wondering why GraphQL even has the concept of variables, instead of just interpolating the value of the variables into the query string. Well, [as mentioned before](../queries-1), the text of the GraphQL query string isn’t available at runtime, because Relay replaces it with a data structure that is more efficient. You can also configure Relay to use [persisted queries](../guides/persisted-queries.md), where the compiler uploads each query to the server at build time and assigns it an ID — in that case, at runtime, Relay is just telling the server “Give me query #1337”, so string interpolation isn't possible and therefore the variables have to come out of band. Even when the query string is available, passing variable values separately eliminates any issues with serializing arbitrary values and escaping strings, above what is required with any HTTP request.
</details>

* * *
Expand Down

0 comments on commit 007eff0

Please sign in to comment.