update-pg
v0.0.7
Published
a Postgres database update script for your migrations
Downloads
2
Readme
Update PG
Update PG is a script for Postgres database migrations.
How it works
Define your database update and migration scripts as .sql
files in pg/pg-updates
, e.g.:
pg/pg-updates
├── public.permissions RLS.sql
├── public.permissions TABLE.sql
├── public.roles RLS.sql
├── public.roles TABLE.sql
├── public.users RLS.sql
├── public.users TABLE.sql
└── public.users TRIGGER.sql
Create a .json
file to define the sequence in which the .sql
files should be run:
{
"updates": [
"public.users TABLE.sql",
"public.roles TABLE.sql",
"public.permissions TABLE.sql",
"public.users TRIGGER.sql",
"public.permissions RLS.sql",
"public.roles RLS.sql",
"public.users RLS.sql",
],
"ignore": []
}
Running update-pg
Provide the following environment variables for the Postgres connection:
PGHOST=<string, host of your pg instance>
PGUSER=<string, user of your pg instance>
PGDATABASE=<string, database name>
PGPASSWORD=<string, password for the user>
PGPORT=<number, port of your pg instance>
optional:
PGSSLREQUIRE=<true/false, require ssl>
PGSSLALLOWSELFSIGNED=<true/false, allow self-signed certificates>
PGSSLCERT=<-----BEGIN CERTIFICATE-----\n[...]\n-----END CERTIFICATE----->
Run node update-pg.mjs
and update-pg will perform the updates in dry-run mode (the actual updates will not be committed).
Run node update-pg.mjs --commit
and update-pg will perform the updates and commit them.