migrate

module
v1.3.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 10, 2018 License: MIT

README

migrate

A migration helper written in Go. Use it in your existing Golang code or run commands via the CLI.

This is lite version of mattes/migrate library for PostgreSQL only. Therefore, the following dependencies are removed:

  • driver for Cassandra
  • driver for MySQL
  • driver for SQLite
GoCode   import github.com/newcloudtechnologies/migrate/migrate

Features

  • Super easy to implement Driver interface.
  • Gracefully quit running migrations on ^C.
  • No magic search paths routines, no hard-coded config files.

Available Drivers

Need another driver? Just implement the Driver interface and open a PR.

Usage in Go

See GoDoc here: http://godoc.org/github.com/newcloudtechnologies/migrate/migrate

import "github.com/newcloudtechnologies/migrate/migrate"

// Import any required drivers so that they are registered and available
import _ "github.com/newcloudtechnologies/migrate/driver/postgres"

// use synchronous versions of migration functions ...
allErrors, ok := migrate.UpSync("driver://url", "./path")
if !ok {
  fmt.Println("Oh no ...")
  // do sth with allErrors slice
}

// use the asynchronous version of migration functions ...
pipe := migrate.NewPipe()
go migrate.Up(pipe, "driver://url", "./path")
// pipe is basically just a channel
// write your own channel listener. see writePipe() in main.go as an example.

Migration files

The format of migration files looks like this:

001_initial_plan_to_do_sth.up.sql     # up migration instructions
001_initial_plan_to_do_sth.down.sql   # down migration instructions
002_xxx.up.sql
002_xxx.down.sql
...

Why two files? This way you could still do sth like psql -f ./db/migrations/001_initial_plan_to_do_sth.up.sql and there is no need for any custom markup language to divide up and down migrations. Please note that the filename extension depends on the driver.

Alternatives

Directories

Path Synopsis
Package driver holds the driver interface.
Package driver holds the driver interface.
bash
Package bash implements the Driver interface.
Package bash implements the Driver interface.
postgres
Package postgres implements the Driver interface.
Package postgres implements the Driver interface.
Package file contains functions for low-level migration files handling.
Package file contains functions for low-level migration files handling.
Package migrate is imported by other Go code.
Package migrate is imported by other Go code.
direction
Package direction just holds convenience constants for Up and Down migrations.
Package direction just holds convenience constants for Up and Down migrations.
Package pipe has functions for pipe channel handling.
Package pipe has functions for pipe channel handling.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL