2020-01-14 15:57:45 +03:00
|
|
|
.. meta::
|
|
|
|
:description: Manage tables and views with the Hasura schema/metadata API
|
|
|
|
:keywords: hasura, docs, schema/metadata API, API reference, table, view
|
|
|
|
|
2020-03-11 22:42:36 +03:00
|
|
|
.. _api_tables_views:
|
|
|
|
|
2018-10-17 08:27:11 +03:00
|
|
|
Schema/Metadata API Reference: Tables/Views
|
2019-02-06 09:39:36 +03:00
|
|
|
===========================================
|
2018-12-03 15:12:24 +03:00
|
|
|
|
|
|
|
.. contents:: Table of contents
|
|
|
|
:backlinks: none
|
|
|
|
:depth: 1
|
|
|
|
:local:
|
|
|
|
|
2019-09-11 10:17:14 +03:00
|
|
|
Track/untrack a table/view in Hasura GraphQL engine.
|
2018-10-17 08:27:11 +03:00
|
|
|
|
2019-02-06 09:39:36 +03:00
|
|
|
Only tracked tables/views are available for querying/mutating/subscribing data over the GraphQL API.
|
2018-10-17 08:27:11 +03:00
|
|
|
|
|
|
|
.. _track_table:
|
|
|
|
|
|
|
|
track_table
|
|
|
|
-----------
|
|
|
|
|
2019-02-06 09:39:36 +03:00
|
|
|
``track_table`` is used to add a table/view to the GraphQL schema.
|
2018-10-17 08:27:11 +03:00
|
|
|
|
|
|
|
Add a table/view ``author``:
|
|
|
|
|
|
|
|
.. code-block:: http
|
|
|
|
|
|
|
|
POST /v1/query HTTP/1.1
|
|
|
|
Content-Type: application/json
|
|
|
|
X-Hasura-Role: admin
|
|
|
|
|
|
|
|
{
|
|
|
|
"type": "track_table",
|
|
|
|
"args": {
|
|
|
|
"schema": "public",
|
|
|
|
"name": "author"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-03 15:12:24 +03:00
|
|
|
.. _track_table_syntax:
|
|
|
|
|
|
|
|
Args syntax
|
|
|
|
^^^^^^^^^^^
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:header-rows: 1
|
|
|
|
|
|
|
|
* - Key
|
|
|
|
- Required
|
|
|
|
- Schema
|
|
|
|
- Description
|
|
|
|
* - table
|
|
|
|
- true
|
|
|
|
- :ref:`TableName <TableName>`
|
|
|
|
- Name of the table
|
2019-08-16 00:19:47 +03:00
|
|
|
* - is_enum
|
|
|
|
- false
|
|
|
|
- Boolean
|
2019-09-03 17:17:36 +03:00
|
|
|
- When set to ``true``, creates the table as an :ref:`enum table <create_enum_table>`.
|
2019-08-16 00:19:47 +03:00
|
|
|
|
|
|
|
.. _set_table_is_enum:
|
|
|
|
|
|
|
|
set_table_is_enum
|
|
|
|
-----------------
|
|
|
|
|
2019-09-03 17:17:36 +03:00
|
|
|
``set_table_is_enum`` sets whether an already-tracked table should be used as an :ref:`enum table <create_enum_table>`.
|
2019-08-16 00:19:47 +03:00
|
|
|
|
|
|
|
Use table ``user_role`` as an enum table:
|
|
|
|
|
|
|
|
.. code-block:: http
|
|
|
|
|
|
|
|
POST /v1/query HTTP/1.1
|
|
|
|
Content-Type: application/json
|
|
|
|
X-Hasura-Role: admin
|
|
|
|
|
|
|
|
{
|
|
|
|
"type": "set_table_is_enum",
|
|
|
|
"args": {
|
|
|
|
"table": {
|
|
|
|
"schema": "public",
|
|
|
|
"name": "user_role"
|
|
|
|
},
|
|
|
|
"is_enum": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.. _set_table_is_enum_syntax:
|
|
|
|
|
|
|
|
Args syntax
|
|
|
|
^^^^^^^^^^^
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:header-rows: 1
|
|
|
|
|
|
|
|
* - Key
|
|
|
|
- Required
|
|
|
|
- Schema
|
|
|
|
- Description
|
|
|
|
* - table
|
|
|
|
- true
|
|
|
|
- :ref:`TableName <TableName>`
|
|
|
|
- Name of the table
|
|
|
|
* - is_enum
|
|
|
|
- true
|
|
|
|
- Boolean
|
|
|
|
- Whether or not the table should be used as an :ref:`enum table <enum table>`.
|
2018-12-03 15:12:24 +03:00
|
|
|
|
2019-09-19 07:47:36 +03:00
|
|
|
.. _track_table_v2:
|
|
|
|
|
|
|
|
track_table v2
|
|
|
|
--------------
|
|
|
|
|
|
|
|
Version 2 of ``track_table`` is used to add a table/view to the GraphQL schema with configuration. You can customise the root field names.
|
|
|
|
|
|
|
|
Add a table/view ``author``:
|
|
|
|
|
|
|
|
.. code-block:: http
|
|
|
|
|
|
|
|
POST /v1/query HTTP/1.1
|
|
|
|
Content-Type: application/json
|
|
|
|
X-Hasura-Role: admin
|
|
|
|
|
|
|
|
{
|
|
|
|
"type": "track_table",
|
|
|
|
"version": 2,
|
|
|
|
"args": {
|
|
|
|
"table": "author",
|
|
|
|
"configuration": {
|
|
|
|
"custom_root_fields": {
|
|
|
|
"select": "Authors",
|
|
|
|
"select_by_pk": "Author",
|
|
|
|
"select_aggregate": "AuthorAggregate",
|
|
|
|
"insert": "AddAuthors",
|
|
|
|
"update": "UpdateAuthors",
|
|
|
|
"delete": "DeleteAuthors"
|
|
|
|
},
|
|
|
|
"custom_column_names": {
|
|
|
|
"id": "authorId"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.. _track_table_args_syntax_v2:
|
|
|
|
|
|
|
|
Args syntax
|
|
|
|
^^^^^^^^^^^
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:header-rows: 1
|
|
|
|
|
|
|
|
* - Key
|
|
|
|
- Required
|
|
|
|
- Schema
|
|
|
|
- Description
|
|
|
|
* - table
|
|
|
|
- true
|
|
|
|
- :ref:`TableName <TableName>`
|
|
|
|
- Name of the table
|
|
|
|
* - configuration
|
|
|
|
- false
|
|
|
|
- :ref:`Table Config <table_config>`
|
|
|
|
- Configuration for the table/view
|
|
|
|
|
|
|
|
.. _table_config:
|
|
|
|
|
|
|
|
Table Config
|
|
|
|
^^^^^^^^^^^^
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:header-rows: 1
|
|
|
|
|
|
|
|
* - Key
|
|
|
|
- Required
|
|
|
|
- Schema
|
|
|
|
- Description
|
|
|
|
* - custom_root_fields
|
|
|
|
- false
|
|
|
|
- :ref:`Custom Root Fields <custom_root_fields>`
|
|
|
|
- Customise the root fields
|
|
|
|
* - custom_column_names
|
|
|
|
- false
|
|
|
|
- :ref:`CustomColumnNames`
|
|
|
|
- Customise the column fields
|
|
|
|
|
|
|
|
.. _custom_root_fields:
|
|
|
|
|
|
|
|
Custom Root Fields
|
|
|
|
^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:header-rows: 1
|
|
|
|
|
|
|
|
* - Key
|
|
|
|
- Required
|
|
|
|
- Schema
|
|
|
|
- Description
|
|
|
|
* - select
|
|
|
|
- false
|
|
|
|
- `String`
|
|
|
|
- Customise the ``<table-name>`` root field
|
|
|
|
* - select_by_pk
|
|
|
|
- false
|
|
|
|
- `String`
|
|
|
|
- Customise the ``<table-name>_by_pk`` root field
|
|
|
|
* - select_aggregate
|
|
|
|
- false
|
|
|
|
- `String`
|
|
|
|
- Customise the ``<table-name>_aggregete`` root field
|
|
|
|
* - insert
|
|
|
|
- false
|
|
|
|
- `String`
|
|
|
|
- Customise the ``insert_<table-name>`` root field
|
|
|
|
* - update
|
|
|
|
- false
|
|
|
|
- `String`
|
|
|
|
- Customise the ``update_<table-name>`` root field
|
|
|
|
* - delete
|
|
|
|
- false
|
|
|
|
- `String`
|
|
|
|
- Customise the ``delete_<table-name>`` root field
|
|
|
|
|
|
|
|
.. _set_table_custom_fields:
|
|
|
|
|
|
|
|
set_table_custom_fields
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
``set_table_custom_fields`` in version ``2`` sets the custom root fields and
|
|
|
|
custom column names of already tracked table. This will **replace** the already
|
|
|
|
present custom fields configuration.
|
|
|
|
|
|
|
|
Set custom fields for table/view ``author``:
|
|
|
|
|
|
|
|
.. code-block:: http
|
|
|
|
|
|
|
|
POST /v1/query HTTP/1.1
|
|
|
|
Content-Type: application/json
|
|
|
|
X-Hasura-Role: admin
|
|
|
|
|
|
|
|
{
|
|
|
|
"type": "set_table_custom_fields",
|
|
|
|
"version": 2,
|
|
|
|
"args": {
|
|
|
|
"table": "author",
|
|
|
|
"custom_root_fields": {
|
|
|
|
"select": "Authors",
|
|
|
|
"select_by_pk": "Author",
|
|
|
|
"select_aggregate": "AuthorAggregate",
|
|
|
|
"insert": "AddAuthors",
|
|
|
|
"update": "UpdateAuthors",
|
|
|
|
"delete": "DeleteAuthors"
|
|
|
|
},
|
|
|
|
"custom_column_names": {
|
|
|
|
"id": "authorId"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.. _set_table_custom_fields_args_syntax:
|
|
|
|
|
|
|
|
Args syntax
|
|
|
|
^^^^^^^^^^^
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:header-rows: 1
|
|
|
|
|
|
|
|
* - Key
|
|
|
|
- Required
|
|
|
|
- Schema
|
|
|
|
- Description
|
|
|
|
* - table
|
|
|
|
- true
|
|
|
|
- :ref:`TableName <TableName>`
|
|
|
|
- Name of the table
|
|
|
|
* - custom_root_fields
|
|
|
|
- false
|
|
|
|
- :ref:`Custom Root Fields <custom_root_fields>`
|
|
|
|
- Customise the root fields
|
|
|
|
* - custom_column_names
|
|
|
|
- false
|
|
|
|
- :ref:`CustomColumnNames`
|
|
|
|
- Customise the column fields
|
|
|
|
|
|
|
|
|
2018-10-17 08:27:11 +03:00
|
|
|
.. _untrack_table:
|
|
|
|
|
|
|
|
untrack_table
|
|
|
|
-------------
|
|
|
|
|
2019-02-06 09:39:36 +03:00
|
|
|
``untrack_table`` is used to remove a table/view from the GraphQL schema.
|
2018-10-17 08:27:11 +03:00
|
|
|
|
|
|
|
Remove a table/view ``author``:
|
|
|
|
|
|
|
|
.. code-block:: http
|
|
|
|
|
|
|
|
POST /v1/query HTTP/1.1
|
|
|
|
Content-Type: application/json
|
|
|
|
X-Hasura-Role: admin
|
|
|
|
|
|
|
|
{
|
|
|
|
"type": "untrack_table",
|
|
|
|
"args": {
|
|
|
|
"table": {
|
|
|
|
"schema": "public",
|
|
|
|
"name": "author"
|
|
|
|
},
|
|
|
|
"cascade": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-16 00:19:47 +03:00
|
|
|
|
2018-10-17 08:27:11 +03:00
|
|
|
.. _untrack_table_syntax:
|
|
|
|
|
|
|
|
Args syntax
|
|
|
|
^^^^^^^^^^^
|
|
|
|
|
|
|
|
.. list-table::
|
|
|
|
:header-rows: 1
|
|
|
|
|
|
|
|
* - Key
|
|
|
|
- Required
|
|
|
|
- Schema
|
|
|
|
- Description
|
|
|
|
* - table
|
|
|
|
- true
|
|
|
|
- :ref:`TableName <TableName>`
|
|
|
|
- Name of the table
|
|
|
|
* - cascade
|
|
|
|
- false
|
|
|
|
- Boolean
|
2019-09-11 10:17:14 +03:00
|
|
|
- When set to ``true``, the effect (if possible) is cascaded to any metadata dependent objects (relationships, permissions, templates)
|