まくろぐ
更新: / 作成:

変数定義と変数値の指定

特定のパラメーターのみ値を変えて複数の GraphQL のクエリを発行したい場合は、ドキュメント内で querymutation を定義するときに、変数定義 (variable definitions) を追加します。

次の GetBook クエリでは、$id: String! という変数定義を行っています。 これは、クエリ実行時に id という名前の文字列変数を参照することを示しています。 そして、型名に ! が付いているので、変数値の指定は必須です。

変数を参照するクエリの例
query GetBook($id: String!) {
  book(id: $id) {
    id
    title
    price
  }
}

指定された id 変数の値は、book フィールドの id 引数として渡され、対応する書籍を取得するリクエストとして処理されます。

肝心の変数の値は、querymutation などのドキュメントとは異なる variables という HTTP ペイロード・フィールドで GraphQL サーバーへ送ります(HTTP POST 経由での GraphQL API 呼び出しの場合)。 ただ、このあたりの variables フィールドの送信に関しては、通常は各種言語用の GraphQL ライブラリに隠蔽されているため、明示的に HTTP POST リクエストのペイロードを設定することはありません。 例えば、React 用の Apollo Client ライブラリは、次のような感じで変数を設定するインタフェースを提供しています。

const { loading, error, data } = useQuery<QueryType, VarType>(query, {
  variables: { id: "book-123" }
})

Web ブラウザ上で GraphQL API のテストを行える GraphiQL(グラフィカル) の UI では、次のようにドキュメントと変数を別々に記述できるようになっています。

/p/dtwtpzj/img-001.png
図: GraphiQL(グラフィカル)での変数指定

変数にデフォルト値を設定する

変数定義時にデフォルト値を設定すると、変数値の指定をオプションにすることができます。 下記の GraphQL クエリは、GitHub の GraphQL API で organization 情報を取得するクエリの例です。

オプショナルな変数
query GetOrganization($org: String = "graphql") {
  organization(login: $org) {
    name
    description
    websiteUrl
    createdAt
  }
}

上記のクエリ変数 $org には、デフォルト値として "graphql" が設定されています。 クエリ実行時に $org 変数の指定を省略した場合、このデフォルト値が使用されます。 変数の指定を省略可能にするため、変数の型は String! ではなく String にしなければいけないことに注意してください。

変数の型として指定できるもの

各変数の型は、次のいずれかである必要があります。

  • スカラー型 (scalar types)
    • IDStringIntFloat などの単一の値を示す型
  • 列挙型 (enum types)
    • スキーマ定義において enum で定義された列挙型
  • 入力型 (input types)
    • スキーマ定義において input で定義された入力用のオブジェクト型

GraphQL スキーマで列挙型や入力型を定義する方法は、下記を参考にしてください。

関連記事

まくろぐ
サイトマップまくへのメッセージ