2020-01-14 15:57:45 +03:00
|
|
|
.. meta::
|
|
|
|
:description: Hasura Migration file format reference
|
|
|
|
:keywords: hasura, docs, migration, file format
|
|
|
|
|
2020-04-29 11:00:26 +03:00
|
|
|
.. _migration_file_format_v2:
|
2019-03-28 13:51:58 +03:00
|
|
|
|
|
|
|
Migration file format reference
|
|
|
|
===============================
|
|
|
|
|
|
|
|
.. contents:: Table of contents
|
|
|
|
:backlinks: none
|
|
|
|
:depth: 1
|
|
|
|
:local:
|
|
|
|
|
2020-04-29 11:00:26 +03:00
|
|
|
Introduction
|
|
|
|
------------
|
|
|
|
|
|
|
|
With ``config v2``, the migrations files are pure SQL files.
|
|
|
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
|
|
For ``config v1``, see :ref:`migration_file_format_v1`.
|
|
|
|
|
2019-03-28 13:51:58 +03:00
|
|
|
Migration filename format
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
Each migration file has the following format:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
2020-04-29 11:00:26 +03:00
|
|
|
<version>_<name>.{up|down}.sql
|
2019-03-28 13:51:58 +03:00
|
|
|
|
|
|
|
A ``version`` which is the Unix timestamp in nanoseconds when the file was
|
|
|
|
created is the first part. Followed by a ``name`` which is either manually added
|
|
|
|
or auto-generated by the console. The next part indicates what step this is. If
|
2020-04-29 11:00:26 +03:00
|
|
|
it is ``up``, it means that this is the forward step, e.g. creating a table.
|
|
|
|
The ``down`` indicates that it is the corresponding
|
|
|
|
rollback step.
|
2019-03-28 13:51:58 +03:00
|
|
|
|
2020-04-29 11:00:26 +03:00
|
|
|
Migration file format
|
|
|
|
---------------------
|
2019-03-28 13:51:58 +03:00
|
|
|
|
2020-04-29 11:00:26 +03:00
|
|
|
A migration SQL file can contain SQL statements which are executed
|
|
|
|
on the apply step of the migration. There can be an ``up`` migration and a ``down``
|
|
|
|
migration file.
|