2018-09-11 14:11:24 +03:00
|
|
|
Troubleshooting Hasura GraphQL Engine Errors
|
|
|
|
============================================
|
|
|
|
|
|
|
|
Hasura GraphQL engine may not work as expected and will throw unexpected errors if the tables/views tracked by
|
2018-10-04 07:09:47 +03:00
|
|
|
the GraphQL engine are altered using ``psql`` or any other PostgreSQL client.
|
2018-09-11 14:11:24 +03:00
|
|
|
|
|
|
|
Hasura GraphQL engine creates and maintains an **internal state** based on the database it is configured to use.
|
|
|
|
This internal state will comprise of information about the tables/views, relationships and access control rules
|
|
|
|
defined on them using Hasura GraphQL engine. See :doc:`Hasura GraphQL engine internals <../engine-internals/index>`
|
|
|
|
for information on how this internal state is maintained. It is highly recommended to do any modifications to the
|
|
|
|
database schema only through Hasura console to avoid corrupting the GraphQL engine's state.
|
|
|
|
|
|
|
|
Following are the list of error messages returned by the GraphQL Engine when it encounters an inconsistent state:
|
|
|
|
|
|
|
|
Error: no such table/view exists in postgres
|
|
|
|
--------------------------------------------
|
|
|
|
|
|
|
|
This error is thrown when a table/view tracked by the Hasura GraphQL engine is deleted or is not available in the
|
|
|
|
database.
|
|
|
|
|
|
|
|
For example, you will encounter the above error if you have:
|
|
|
|
|
|
|
|
- Created/tracked a table called ``author`` from console.
|
2018-10-04 07:09:47 +03:00
|
|
|
- Opened ``psql`` or ``adminer`` or any other PostgreSQL client and deleted ``author`` table.
|
2018-09-11 14:11:24 +03:00
|
|
|
- Restarted GraphQL engine.
|
|
|
|
|
|
|
|
In this example, the GraphQL engine expects the table ``author`` to be available in the database to
|
|
|
|
function properly but it can't find it.
|
|
|
|
|
|
|
|
Solution
|
|
|
|
^^^^^^^^
|
|
|
|
|
|
|
|
- Connect to the database and switch to ``hdb_catalog`` schema.
|
|
|
|
- Delete the row from ``hdb_table`` table where the column ``table_name`` has the value ``author``.
|
|
|
|
- Restart GraphQL engine to verify.
|
|
|
|
|
|
|
|
Error: no foreign constraint exists on the given column
|
|
|
|
-------------------------------------------------------
|
|
|
|
|
|
|
|
Hasura GraphQL Engine validates all the relationships (created using foreign key/manually) before it starts serving.
|
|
|
|
When it encounters a relationship defined from table ``A -> B`` it looks for a foreign key constraint in table ``A``
|
|
|
|
and when it can't find it, it throws the above error.
|
|
|
|
|
|
|
|
Solution
|
|
|
|
^^^^^^^^
|
|
|
|
|
|
|
|
- Connect to the database and switch to ``hdb_catalog`` schema.
|
|
|
|
- In the ``hdb_relationship`` table, find the entry for the above relationship and delete it.
|
|
|
|
- Restart GraphQL engine to verify.
|
|
|
|
|
|
|
|
Error: field already exists
|
|
|
|
---------------------------
|
|
|
|
|
|
|
|
When a relationship is created using Hasura GraphQL Engine, it creates a special field with the relationship name
|
|
|
|
which is used while fetching nested objects using GraphQL.
|
|
|
|
|
|
|
|
Let's say we have tables called ``article`` and ``author`` as follows:
|
|
|
|
|
|
|
|
.. image:: ../../../img/graphql/manual/troubleshooting/author_article.jpg
|
|
|
|
:alt: article author schema
|
|
|
|
|
|
|
|
Using the console if you have created a relationship with name as ``author`` from ``article`` table to
|
|
|
|
``author`` table, Hasura GraphQL engine will create a special field ``author`` in the ``article`` table in its
|
|
|
|
internal state. This field will be available via the GraphQL interface.
|
|
|
|
|
|
|
|
When this table is described using ``psql``, ``author`` field will not be available as part of the list of fields
|
|
|
|
returned by the describe command as it is something added by Hasura GraphQL engine. Now if a new column is created
|
|
|
|
with the same name, i.e. ``author``, via ``psql``, Hasura GraphQL engine will throw the above error when restarted as it has two
|
|
|
|
references to the ``author`` field for the ``article`` table.
|
|
|
|
|
|
|
|
Solution
|
|
|
|
^^^^^^^^
|
|
|
|
|
|
|
|
- Delete the problematic column from the table.
|
|
|
|
- Restart GraphQL engine to verify.
|
|
|
|
|
|
|
|
OR
|
|
|
|
|
|
|
|
- Connect to the database and switch to ``hdb_catalog`` schema.
|
|
|
|
- In the ``hdb_relationship`` table, find the entry for the above relationship and delete it.
|
|
|
|
- Restart GraphQL engine to verify.
|