GraphQL — это мощный язык запросов, который позволяет клиентам запрашивать с сервера только те данные, которые им нужны. Это помогает вам увеличить скорость запросов, поскольку вы можете настраивать запросы для получения только определенных данных.
GraphQL имеет два типа операций: запросы и мутации. Несмотря на их сходство, они служат совершенно разным целям.
Различия между запросами GraphQL и мутациями
Запросы и мутации похожи в том, что вы используете их для запросов к API-интерфейсы GraphQL. Однако они различаются синтаксисом, режимом выполнения и использованием.
Синтаксис запросов и мутаций
Основной синтаксис запроса GraphQL следующий:
запрос getProduct($id: ID!) {
продукт (идентификатор: $id) {
имя
цена
}
}
Вот что означает этот код:
- query — это ключевое слово, которое идентифицирует запрос как запрос.
- getProduct — имя операции
- $id - это переменная
- ИДЕНТИФИКАТОР! является типом переменной.
Если вам не нужны переменные, опустите их и определите запрос следующим образом:
запрос getProducts {
продукты {
имя
цена
}
}
В некоторых ситуациях вы можете опустить ключевое слово и имя запроса, написав запрос GraphQL следующим образом:
продукты {
имя
цена
}
Хотя этот формат работает, использование ключевого слова запроса лучше для удобочитаемости.
Синтаксис мутаций аналогичен запросам, за исключением использования ключевого слова мутации.
мутация AddNewProduct ($name: String!, $price: Number!) {
addProduct (имя: $имя, цена: $цена) {
имя
цена
}
}
Различные режимы выполнения
Другое различие между запросом и мутацией заключается в том, что запросы выполняются параллельно, а мутации выполняются синхронно. Когда вы запускаете две мутации, они будут выполняться одна за другой, чтобы
Различное использование запросов и мутаций
Вы должны использовать запросы только для операций READ. Например, используйте запрос при получении продуктов из конечной точки API.
Используйте мутации для операций CREATE, UPDATE и DELETE. По сути, это операции, которые изменяют данные, хранящиеся в базе данных.
Например, используйте мутацию при обновлении имени клиента через конечную точку заказов.
Выработайте привычку правильно использовать запросы и мутации
GraphQL — это мощный язык запросов, который позволяет вам запрашивать только те данные, которые вам нужны. В GraphQL можно выполнять две операции: запросы и мутации.
Эти операции различаются синтаксисом, выполнением и предполагаемым использованием. Вы должны использовать запросы для операций READ и мутации для операций CREATE, UPDATE и DELETE.