mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-18 04:51:35 +03:00
63 lines
2.8 KiB
ReStructuredText
63 lines
2.8 KiB
ReStructuredText
|
Setting up schema using an existing database
|
||
|
============================================
|
||
|
|
||
|
When you have an existing database with a schema already present, you don't need to create tables or views or run
|
||
|
DDL queries through the Hasura console.
|
||
|
|
||
|
All you need to do is indicate to Hasura GraphQL engine, which tables and views you want to expose over GraphQL and
|
||
|
how they are connected to each other so that you can query them as a "graph".
|
||
|
|
||
|
1) Track tables/views
|
||
|
---------------------
|
||
|
|
||
|
Tracking a table or a view means telling Hasura GraphQL engine that you want to expose that table/view over GraphQL.
|
||
|
|
||
|
To track a table or a view:
|
||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||
|
|
||
|
#. Head to the ``Data -> Schema`` section of the console.
|
||
|
#. Under the heading ``Untracked Tables/Views``, click on the ``Add`` button next to the table/view name.
|
||
|
|
||
|
To track all tables and views present in the database:
|
||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||
|
|
||
|
#. Head to the ``Data -> Schema`` section of the console.
|
||
|
#. Under the heading ``Untracked Tables/Views``, click the ``Add all`` button.
|
||
|
|
||
|
2) Track foreign-keys
|
||
|
---------------------
|
||
|
|
||
|
Tracking a foreign-key means creating a :doc:`relationship <relationships/index>` between the tables involved in the foreign
|
||
|
key.
|
||
|
|
||
|
To track a foreign-key between two tables in the database:
|
||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||
|
|
||
|
#. Head to the ``Data -> Schema`` section of the console.
|
||
|
#. Click on a table involved in the foreign-key and head to the ``Relationships`` tab.
|
||
|
#. You should see a suggested relationship based on the foreign-key. Click ``Add``, give a name to your relationship
|
||
|
(this will be the name of the :doc:`nested object <../queries/nested-object-queries>` in the GraphQL query) and
|
||
|
hit ``Save`` to create the relationship.
|
||
|
#. Repeat with the other table involved in the foreign-key.
|
||
|
|
||
|
|
||
|
To track all the foreign-keys of all tables in the database:
|
||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||
|
|
||
|
#. Head to the ``Data -> Schema`` section of the console.
|
||
|
#. Under the heading ``Untracked Relations``, click on the ``Track Available Relations`` to automatically create
|
||
|
relationships based on the foreign-keys.
|
||
|
|
||
|
.. note::
|
||
|
|
||
|
In this case, Hasura GraphQL engine will automatically generate relationship names (the names of the :doc:`nested
|
||
|
objects <../queries/nested-object-queries>` in the GraphQL query) based on the table names and the foreign-key
|
||
|
names. The name is generated in the following format:
|
||
|
|
||
|
- For object relationships: ``Camel case of (foreignTableName + By + columnName)``
|
||
|
- For array relationships: ``Camel case of (foreignTableName + s + By + columnNameInForeignTable)``
|
||
|
|
||
|
For example, for the foreign-key ``article::author_id -> author::id``, the relationship names will be
|
||
|
``authorByAuthorId`` for ``article`` table and ``articlesByAuthorId`` for ``author`` table.
|
||
|
|