Skip to content

AlexanderMac/gom

Repository files navigation

gom

A database migration tool for Go applications

Build Status Go Report Card Go Docs License GitHub tag

Gom is a database migration tool. Requires Go v1.18 or higher. It can be run as a command-line tool or injected into the application using embedding SQL migrations.

Contents

Features

  • Supports SQLite
  • CLI
  • Embedded migrations
  • Plain SQL for writing schema migrations
  • Incremental migration version using timestamps
  • Run migrations inside a transaction
  • Works in Go v1.18+

Install

go install github.com/alexandermac/gom/cmd/gom@latest

Usage

CLI

gom [FLAGS] DRIVER DBSTRING COMMAND

Flags:
  --dir                Migrations directory name (absolute or relative path)
  --name               A new migration file suffix
  --verbose            Prints debug information

Drivers:
  sqlite

Commands:
  help                 Shows this help
  version              Prints app version
  init                 Creates the migration directory with a sample migration file and the migrations table in the database
  create               Creates a new migration file
  migrate              Migrates the DB to the most recent version available
  rollback             Roll backs the version by 1

Examples:
  gom --dir db_migrations sqlite ./foo.db init
  gom --dir db_migrations --name create_users sqlite ./foo.db create
  gom sqlite ./foo.db migrate
  gom sqlite ./foo.db rollback

Embedded migrations

It's possible to embed sql files into binary and corresponding filesystem abstraction. Such migrations can be applied when the app starts.

package main

import (
    "database/sql"
    "embed"

    "github.com/alexandermac/gom"
)

//go:embed my_migrations
var migrationsDir embed.FS

func main() {
	// connect the database

	log.Println("Migrating the database")
	gom.SetBaseFS(migrationsDir)
	gom.SetMigrationsDir("my_migrations")
	if err := gom.Migrate(db); err != nil {
		panic(err)
	}
}

API

func SetBaseFS(fsys simpleFS)

Sets a base file system to discover migrations. Call this function to pass an embedded migrations variable.

func SetMigrationsDir(dir string)

Sets the migrations directory.

func SetLogger(l Logger)

Sets the logger. Must be compatible with gom.Logger interface.

func Create(dir, name, content string) error

Creates a new migration file. Used in CLI tool.

func Migrate(db *sql.DB) error

Migrates the DB to the most recent version available.

func Rollback(db *sql.DB) error

Roll backs the version by 1.

License

Licensed under the MIT license.

Author

Alexander Mac

About

A database migration tool for Go applications

Resources

License

Stars

Watchers

Forks

Packages

No packages published