2019-01-04 20:25:48 +03:00
|
|
|
Troubleshooting Hasura GraphQL Engine errors
|
2018-09-11 14:11:24 +03:00
|
|
|
============================================
|
|
|
|
|
2018-12-03 15:12:24 +03:00
|
|
|
.. contents:: Table of contents
|
|
|
|
:backlinks: none
|
|
|
|
:depth: 1
|
|
|
|
:local:
|
|
|
|
|
2018-09-11 14:11:24 +03:00
|
|
|
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.
|
2018-10-20 06:22:13 +03:00
|
|
|
This internal state will comprise information about the tables/views, relationships and access control rules
|
2019-01-04 20:25:48 +03:00
|
|
|
defined on them using Hasura GraphQL engine. See :doc:`Hasura GraphQL metadata schema <../how-it-works/metadata-schema>`
|
2018-10-20 06:22:13 +03:00
|
|
|
for information on how this internal state is maintained. It is highly recommended doing any modifications to the
|
2018-09-11 14:11:24 +03:00
|
|
|
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
|
|
|
|
--------------------------------------------
|
|
|
|
|
2019-04-17 16:37:42 +03:00
|
|
|
This error is thrown when a table/view tracked by the Hasura GraphQL engine is not available in the
|
2018-09-11 14:11:24 +03:00
|
|
|
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:
|
|
|
|
|
2019-03-13 13:03:45 +03:00
|
|
|
.. thumbnail:: ../../../img/graphql/manual/troubleshooting/author_article.jpg
|
2018-09-11 14:11:24 +03:00
|
|
|
: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.
|
2019-04-17 16:37:42 +03:00
|
|
|
|
|
|
|
Error: column does not exist
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
This error is thrown when a column of a table used by the Hasura GraphQL engine is not available in the
|
|
|
|
database.
|
|
|
|
|
|
|
|
For example, you will encounter the above error if you have:
|
|
|
|
|
|
|
|
- Created a permission rule using a column in a check.
|
|
|
|
- Opened ``psql`` or ``adminer`` or any other PostgreSQL client and deleted the column from the table.
|
|
|
|
- Restarted GraphQL engine.
|
|
|
|
|
|
|
|
In this example, the GraphQL engine expects the column to be available in the table 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_permission`` table where the column ``table_name`` has the value same as the table
|
|
|
|
mentioned in the error and the column ``perm_def`` involves the missing column.
|
|
|
|
- Restart GraphQL engine to verify.
|