2018-09-11 14:11:24 +03:00
.. title :: API Reference - Query/Subscription
API Reference - Query/Subscription
==================================
Query/Subscription syntax
-------------------------
.. code-block :: none
query|subscription [<op-name> ] {
object [([argument])]{
object-fields
}
}
.. list-table ::
:header-rows: 1
* - Key
- Required
- Schema
- Description
* - op-name
- false
- Value
- Name query/subscription for observability
* - object
- true
- Object_
- Name of the table/object
* - argument
- false
- Argument_
- one or more of filter criteria, instructions for sort order or pagination
**E.g. QUERY** :
.. code-block :: graphql
query {
author(where: {articles: {rating: {_gte: 4}}} order_by: name_asc) {
id
name
}
}
**E.g. SUBSCRIPTION** :
.. code-block :: graphql
subscription {
author(where: {articles: rating: {_gte: 4}}} order_by: name_asc) {
id
name
}
}
.. note ::
For more examples and details of usage, please see :doc: `this <../queries/index>` .
Syntax definitions
------------------
.. _Object:
Object
^^^^^^
.. code-block :: none
object-name {
field1
field2
..
nested object1
nested object2
..
}
E.g.
.. code-block :: graphql
author {
id # scalar field
name # scalar field
article { # nested object
title
}
}
.. _Argument:
Argument
^^^^^^^^
.. parsed-literal ::
WhereExp_ | OrderByExp_ | PaginationExp_
.. _WhereExp:
WhereExp
***** ***
.. parsed-literal ::
where: BoolExp_
.. _BoolExp:
BoolExp
"""""""
.. parsed-literal ::
AndExp_ | OrExp_ | NotExp_ | ColumnExp_
AndExp
######
.. parsed-literal ::
{
_and: [BoolExp_]
}
OrExp
#####
.. parsed-literal ::
{
_or: [BoolExp_]
}
NotExp
######
.. parsed-literal ::
{
_not: BoolExp_
}
ColumnExp
#########
.. parsed-literal ::
{
field-name : {Operator_: Value }
}
Operator
########
Generic operators (all column types except json, jsonb) :
- `` _eq ``
2018-09-20 12:51:27 +03:00
- `` _neq ``
2018-09-11 14:11:24 +03:00
- `` _in ``
- `` _nin ``
- `` _gt ``
- `` _lt ``
- `` _gte ``
- `` _lte ``
2018-09-20 12:51:27 +03:00
JSONB operators:
2018-09-11 14:11:24 +03:00
2018-09-20 12:51:27 +03:00
.. list-table ::
:header-rows: 1
* - Operator
- PostgreSQL equivalent
* - `` _contains ``
- `` @> ``
* - `` _contained_in ``
- `` <@ ``
* - `` _has_key ``
- `` ? ``
* - `` _has_keys_any ``
- `` ?| ``
* - `` _has_keys_all ``
- `` ?& ``
(For more details on what these operators do, refer `Postgres docs <https://www.postgresql.org/docs/current/static/functions-json.html#FUNCTIONS-JSONB-OP-TABLE> `_ .)
2018-09-11 14:11:24 +03:00
Text related operators :
- `` _like ``
- `` _nlike ``
- `` _ilike ``
- `` _nilike ``
- `` _similar ``
- `` _nsimilar ``
Checking for `` null `` values :
- `` _is_null `` (takes true/false as values)
2018-09-20 12:51:27 +03:00
2018-09-11 14:11:24 +03:00
.. _OrderByExp:
OrderByExp
***** *****
.. parsed-literal ::
order_by: (object-field + OrderByOperator_ | [object-field + OrderByOperator_])
E.g.
.. code-block :: graphql
order_by: name_asc
or
.. code-block :: graphql
order_by: [name_asc, id_desc]
.. _OrderByOperator:
OrderByOperator
"""""""""""""""
- `` _asc ``
- `` _desc ``
- `` _asc_nulls_first ``
- `` _desc_nulls_first ``
.. _PaginationExp:
PaginationExp
***** ***** ***
.. parsed-literal ::
limit: Integer [offset: Integer]