mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-17 04:24:35 +03:00
c0d2bc6653
add remote joins: Create relationships across database and remote schemas (#2392) Co-authored-by: Aleksandra Sikora <ola.zxcvbnm@gmail.com> Co-authored-by: Chris Done <chrisdone@gmail.com> Co-authored-by: Chris Done <github@chrisdone.com> Co-authored-by: wawhal <rishichandra.wawhal@gmail.com> Co-authored-by: Aravind Shankar <aravind@hasura.io> Co-authored-by: Brandon Simmons <brandon.m.simmons@gmail.com> Co-authored-by: Rishichandra Wawhal <rishi@hasura.io> Co-authored-by: Brandon Simmons <brandon@hasura.io> Co-authored-by: nizar-m <19857260+nizar-m@users.noreply.github.com> Co-authored-by: Praveen Durairaju <praveend.web@gmail.com> Co-authored-by: rakeshkky <12475069+rakeshkky@users.noreply.github.com> Co-authored-by: Anon Ray <rayanon004@gmail.com> Co-authored-by: Shahidh K Muhammed <shahidh@hasura.io> Co-authored-by: soorajshankar <soorajshankar@users.noreply.github.com> Co-authored-by: Sooraj Sanker <sooraj@Soorajs-MacBook-Pro.local> Co-authored-by: Karthikeyan Chinnakonda <karthikeyan@hasura.io> Co-authored-by: Aleksandra Sikora <ola.zxcvbnm@gmail.com>
263 lines
5.5 KiB
ReStructuredText
263 lines
5.5 KiB
ReStructuredText
.. meta::
|
|
:description: Manage remote relationships with the Hasura schema/metadata API
|
|
:keywords: hasura, docs, schema/metadata API, API reference, remote joins, remote relationships
|
|
|
|
Schema/Metadata API Reference: Remote Relationships
|
|
===================================================
|
|
|
|
.. contents:: Table of contents
|
|
:backlinks: none
|
|
:depth: 1
|
|
:local:
|
|
|
|
Remote Relationships allow you to join tables with remote schemas.
|
|
|
|
.. _create_remote_relationship:
|
|
|
|
create_remote_relationship
|
|
--------------------------
|
|
|
|
``create_remote_relationship`` is used to create a new remote relationship with an existing remote schema.
|
|
|
|
.. code-block:: http
|
|
|
|
POST /v1/query HTTP/1.1
|
|
Content-Type: application/json
|
|
X-Hasura-Role: admin
|
|
|
|
{
|
|
"type":"create_remote_relationship",
|
|
"args":{
|
|
"name": "sample_remote_relationship",
|
|
"table": "users",
|
|
"hasura_fields": ["id"],
|
|
"remote_schema": "my-remote-schema",
|
|
"remote_field": {
|
|
"messages": {
|
|
"arguments": {
|
|
"id":"$id"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.. _create_remote_relationship_syntax:
|
|
|
|
Args syntax
|
|
^^^^^^^^^^^
|
|
|
|
.. list-table::
|
|
:header-rows: 1
|
|
|
|
* - Key
|
|
- Required
|
|
- Schema
|
|
- Description
|
|
* - name
|
|
- true
|
|
- RemoteRelationshipName_
|
|
- Name of the remote relationship
|
|
* - table
|
|
- true
|
|
- :ref:`QualifiedTable <QualifiedTable>`
|
|
- Object with table name and schema
|
|
* - hasura_fields
|
|
- true
|
|
- [:ref:`PGColumn <PGColumn>`]
|
|
- Column(s) in the table that is used for joining with remote schema field. All join keys in ``remote_field`` must appear here.
|
|
* - remote_schema
|
|
- true
|
|
- :ref:`RemoteSchemaName <RemoteSchemaName>`
|
|
- Name of the remote schema to join with
|
|
* - remote_field
|
|
- true
|
|
- RemoteField_
|
|
- The schema tree ending at the field in remote schema which needs to be joined with.
|
|
|
|
.. _update_remote_relationship:
|
|
|
|
update_remote_relationship
|
|
--------------------------
|
|
|
|
``update_remote_relationship`` is used to update an existing remote relationship.
|
|
|
|
.. code-block:: http
|
|
|
|
POST /v1/query HTTP/1.1
|
|
Content-Type: application/json
|
|
X-Hasura-Role: admin
|
|
|
|
{
|
|
"type": "update_remote_relationship",
|
|
"args": {
|
|
"name": "sample_remote_relationship",
|
|
"table": "users",
|
|
"hasura_fields": ["id"],
|
|
"remote_schema": "my-remote-schema",
|
|
"remote_field": {
|
|
"posts": {
|
|
"arguments": {
|
|
"id": "$id",
|
|
"likes": {
|
|
"lte":"1000"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.. _update_remote_relationship_syntax:
|
|
|
|
Args syntax
|
|
^^^^^^^^^^^
|
|
|
|
.. list-table::
|
|
:header-rows: 1
|
|
|
|
* - Key
|
|
- Required
|
|
- Schema
|
|
- Description
|
|
* - name
|
|
- true
|
|
- RemoteRelationshipName_
|
|
- Name of the remote relationship
|
|
* - table
|
|
- true
|
|
- :ref:`QualifiedTable <QualifiedTable>`
|
|
- Object with table name and schema
|
|
* - hasura_fields
|
|
- true
|
|
- [:ref:`PGColumn <PGColumn>`]
|
|
- Column(s) in the table that is used for joining with remote schema field. All join keys in ``remote_field`` must appear here.
|
|
* - remote_schema
|
|
- true
|
|
- :ref:`RemoteSchemaName <RemoteSchemaName>`
|
|
- Name of the remote schema to join with
|
|
* - remote_field
|
|
- true
|
|
- RemoteField_
|
|
- The schema tree ending at the field in remote schema which needs to be joined with.
|
|
|
|
.. _delete_remote_relationship:
|
|
|
|
delete_remote_relationship
|
|
--------------------------
|
|
|
|
``delete_remote_relationship`` is used to delete an existing remote relationship.
|
|
|
|
.. code-block:: http
|
|
|
|
POST /v1/query HTTP/1.1
|
|
Content-Type: application/json
|
|
X-Hasura-Role: admin
|
|
|
|
{
|
|
"type" : "delete_remote_relationship",
|
|
"args" : {
|
|
"table":{
|
|
"name":"users",
|
|
"schema":"public"
|
|
},
|
|
"name":"sample_remote_relationship"
|
|
}
|
|
}
|
|
|
|
.. _delete_remote_relationship_syntax:
|
|
|
|
Args syntax
|
|
^^^^^^^^^^^
|
|
|
|
.. list-table::
|
|
:header-rows: 1
|
|
|
|
* - Key
|
|
- Required
|
|
- Schema
|
|
- Description
|
|
* - table
|
|
- true
|
|
- :ref:`QualifiedTable <QualifiedTable>`
|
|
- Object with table name and schema
|
|
* - name
|
|
- true
|
|
- RemoteRelationshipName_
|
|
- Name of the remote relationship
|
|
|
|
.. _RemoteRelationshipName:
|
|
|
|
RemoteRelationshipName
|
|
&&&&&&&&&&&&&&&&&&&&&&
|
|
|
|
.. parsed-literal::
|
|
|
|
String
|
|
|
|
|
|
RemoteField
|
|
&&&&&&&&&&&
|
|
|
|
.. parsed-literal::
|
|
:class: haskell-pre
|
|
|
|
{
|
|
FieldName: {
|
|
"arguments": InputArguments
|
|
"field": RemoteField # optional
|
|
}
|
|
}
|
|
|
|
|
|
``RemoteField`` is a recursive tree structure that points to the field in the remote schema that needs to be joined with. It is recursive because the remote field maybe nested deeply in the remote schema.
|
|
|
|
Examples:
|
|
|
|
.. code-block:: http
|
|
|
|
POST /v1/query HTTP/1.1
|
|
Content-Type: application/json
|
|
X-Hasura-Role: admin
|
|
|
|
{
|
|
"message": {
|
|
"arguments":{
|
|
"message_id":"$id"
|
|
}
|
|
}
|
|
}
|
|
|
|
.. code-block:: http
|
|
|
|
POST /v1/query HTTP/1.1
|
|
Content-Type: application/json
|
|
X-Hasura-Role: admin
|
|
|
|
{
|
|
"messages": {
|
|
"arguments": {
|
|
"limit": 100
|
|
},
|
|
"field": {
|
|
"private": {
|
|
"arguments": {
|
|
"id" : "$id"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
InputArguments
|
|
&&&&&&&&&&&&&&
|
|
|
|
.. parsed-literal::
|
|
:class: haskell-pre
|
|
|
|
{
|
|
InputField : $PGColumn | Scalar
|
|
}
|
|
|
|
Table columns can be referred by prefixing ``$`` e.g ``$id``.
|