This package provides common database code for use across other packages within this mono-repo.
See https://github.com/beyondessential/tupaia/blob/dev/packages/database/src/index.js for the list of externally available exports
Handily, yarn workspaces is able to treat this as a package being pulled from npm, but we never actually have to publish it. In order to use it in other packages, simply run (for example)
yarn workspace @tupaia/central-server add @tupaia/database@1.0.0
and then import from @tupaia/database as though it were any other dependency.
After making changes to the code in this package, you must run
yarn workspace @tupaia/database build
(or simply yarn
at the root level, which builds every internal dependency as a preinstall step)
for those changes to be transpiled down and reflected in other packages
- Run the command
yarn run migrate-create
, you will be prompted to define a name that accurately describes your migration (eg createUserTable ). - A file will be created in
src/migrations
which is prefixed with the current timestamp and contains your chosen name. - For examples, you can look at
src/migrations
, or visit the documentation at https://db-migrate.readthedocs.io/en/latest/API/SQL/.
- Run
yarn run migrate
. - You can verify that a migration has run by checking the
migrations
table in the database. - To debug what's actually run add a
--verbose
flag
- Think of migrations as create and patch. If you don't get the schema right the first time you can always patch it later with another migration that adds/removes columns or renames things.
Migrations using db-migrate work in a similar way to Laravel and Rails. When running migrate, the script will scan the src/migrations
directory and find any files that haven't been added to the migrations
table of the database. The files will then be executed in alphabetical order and, on each successful migration, a record will be stored in the database to indicate the migration completed and should not be run in the future.
A migration file can be technically called anything however the standard is to prefix it with the current time to guarantee alphabetical order. Migrations function more as patch files than schema definitions. For example if, in a previous migration, a developer created a column that they no longer require they would create a new migration that removes that column and not edit the previous migration to remove the column. A migration is a paper trail of database changes. You wouldn't rewrite commits in GIT in order to fix a bug, similarly you wouldn't rewrite migrations to change schema.
We keep a copy of the schema in schema/schema.sql. This is used to spin up a new database e.g. as a test database or a new deployment
of Tupaia. Periodically this should be updated (yarn update-schema
) to squash the schema migrations into it.'
When implementing a change handler, you MUST have a trigger on the record type in the database. This can be added through a migration. If this is not added, the change handler will not work.
Change handlers get initialised in the central-server
in the index.js
file.