A tool to create and manage SQL migrations.
Every call to dbmigrate requires 2 arguments: database url and migrations folder.
Those can be set through environment variables: DBMIGRATE_URL
and DBMIGRATE_PATH
, using a .env file, or as args to a call. Argument will override an environment variable.
```bash
dbmigrate --url postgres://.. --path ./migrations create my_name
dbmigrate --url postgres://.. --path ./migrations up
dbmigrate --url postgres://.. --path ./migrations down
dbmigrate --url postgres://.. --path ./migrations redo
dbmigrate --url postgres://.. --path ./migrations revert
dbmigrate --url postgres://.. --path ./migrations status ```
The format of the migration files is the following:
bash
0001.initial_db.up.sql
0001.initial_db.down.sql
You can also pass a string to create
and dbmigrate will slugify it for you:
```bash dbmigrate --url postgres://.. --path ./migrations create "change currency table"
0001.changecurrencytable.up.sql 0001.changecurrencytable.down.sql ```
.
(dot) is not allowed in a migration name as it is the filename separator character.
Migrations can also be done programmatically and is how the CLI tool is built.
You will need to add the dbmigrate-lib
dependency to your Cargo.toml
file. The best example to see how how to make it work
is to look at the dbmigrate
directory, which uses it to implement the CLI tool.
Build the project first with cargo build
.
Assuming you use the docker images in the Makefile for pg and mysql:
Postgres:
bash
./target/release/dbmigrate --url=postgres://pg@localhost:5777/migrate --path=/my/full/path/migrations status
MySQL:
bash
./target/release/dbmigrate --url=mysql://mg:pass@localhost:5789/migrate --path=/my/full/path/migrations status
For Sqlite I have a Sqlite db named dbmigrate.db
in the repo (gitignored):
bash
./target/release/dbmigrate --path=/home/vincent/Code/dbmigrate/examples/migrations --url=sqlite:///dbmigrate.db status
dbmigrate will use the default schema. You can override that from your database URL, for example for Postgres:
--url="postgres://postgres:@127.0.0.1:5432/migrate?application_name=my_app&options=-c search_path%3Dmy_app"
postgres-native-tls
This is heavily inspired by https://github.com/mattes/migrate.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.