Overview of GraphQL

The monday.com API is built with GraphQL, a flexible query language that allows you to return as much or as little data as you need. It's important to know that GraphQL is an application layer that parses the query you send it and returns (or changes) data accordingly.

Unlike REST APIs where there are multiple endpoints returning different data, GraphQL always exposes one endpoint and allows you to determine the structure of the returned data.

The result of each query will be formatted in the same way as the query itself.

In the following section we’re going to have a quick look into to GraphQL components.



For a deep-dive into what you can do with GraphQL, check out the GraphQL Foundation's introduction here.


In GraphQL there are two possible operations: queries and mutations.


A query performs the READ operation and does not change or alter any data.


A mutation is a special type of query that performs the CUD (Create, Update, Delete) operations to modify your data. Mutations return an instance of the object you just modified, so you can query the data you changed.

Below is an example of a create_item() mutation that will return the ID and the name of the newly created item:

  create_item(board_id: 1234567, item_name: "New Item"){

Object Types

Object types are a collection of fields, which are used to describe the set of possible data you can query using the API.


Fields specify certain properties of objects.

Each object contains fields that can be queried by name to retrieve specific properties of the object.

query {
    boards {


You can pass arguments in a query to determine the returned data (i.e. filtering the search results) and to narrow down the results to only the specific ones you’re after.

In the following example, the object is “boards”, the requested field is “title”, the argument is “ids”, and the argument value is 157244624.

query {
    boards (ids: 1234567){

GraphQL Visual Interface (GraphiQL)

One of the most powerful parts of GraphQL is its visual interface. GraphiQL is an in-browser tool for writing, validating, and testing GraphQL queries.

Before diving in and querying the API, it’s highly recommended for you to run your queries through this visual interface. This will allow you to ensure that your queries are correct, and the data being returned is expected.

GraphiQL is available in the Playground here.


Variables can be used to pass dynamic values to your arguments. Variables are written outside of the query string itself, in the variables section, and passed to the arguments.

When we start working with variables, we need to do three things:

  1. Replace the static value in the query with $variableName
  2. Declare $variableName as one of the variables accepted by the query
  3. Pass variableName: value in the separate, transport-specific (usually JSON) variables dictionary
mutation change_column_value($value: JSON!) {
    change_column_value (board_id: 157244624,item_id: 9539475, column_id: "status", value: $value) {

query variables:
"value": "{\"index\": 1}"

Did this page help you?