カテゴリ: Go言語 更新日: 2026/02/06

Go言語でのマイグレーションツールの使い方完全ガイド!初心者でもわかるgolang-migrate活用法

Go言語のマイグレーションツール(golang-migrateなど)の使い方
Go言語のマイグレーションツール(golang-migrateなど)の使い方

先生と生徒の会話形式で理解しよう

生徒

「Go言語でデータベースを作ったり変更したりするのに、毎回SQLを書かないといけないんですか?」

先生

「毎回手で書くとミスが増えます。そこで便利なのがマイグレーションツールです。Go言語ではgolang-migrateというツールがよく使われます。」

生徒

「マイグレーションって何ですか?」

先生

「マイグレーションとは、データベースの設計や構造の変更履歴を管理する仕組みです。簡単に言うと、データベースのバージョン管理のようなものです。」

生徒

「それなら、複数人で開発しても変更が衝突しにくいですね。」

先生

「その通りです。それでは基本的な使い方を順番に見ていきましょう。」

1. golang-migrateのインストール

1. golang-migrateのインストール
1. golang-migrateのインストール

まずはgolang-migrateをインストールします。Go言語で簡単にインストールでき、コマンドラインから操作できます。


go install -tags 'postgres' github.com/golang-migrate/migrate/v4/cmd/migrate@latest

このコマンドでPostgreSQL用のマイグレーションツールをインストールできます。MySQLやSQLiteを使う場合も、タグを変えるだけで対応可能です。

2. マイグレーションファイルの作成

2. マイグレーションファイルの作成
2. マイグレーションファイルの作成

マイグレーションファイルは、データベースの変更内容を記述するファイルです。上方向の変更(CREATE TABLEなど)と、下方向の変更(DROP TABLEなど)を分けて作成します。


migrate create -ext sql -dir db/migrations create_users_table

このコマンドでdb/migrationsディレクトリに、上方向用と下方向用のSQLファイルが作られます。

3. マイグレーションの適用

3. マイグレーションの適用
3. マイグレーションの適用

作成したマイグレーションファイルをデータベースに反映させます。アップ(apply)コマンドで変更を適用できます。


migrate -path db/migrations -database "postgres://user:pass@localhost:5432/dbname?sslmode=disable" up

これで、ユーザーテーブルなどの変更がデータベースに反映されます。必要に応じて、複数のマイグレーションを順番に適用できます。

Go言語を基礎からスッキリ学びたい人や、 文法だけでなく「実用的な使い方」まで押さえたい人には、 定番の入門書がこちらです。

基礎からわかるGo言語をAmazonで見る

※ Amazon広告リンク

4. マイグレーションのロールバック

4. マイグレーションのロールバック
4. マイグレーションのロールバック

間違えた場合や、以前の状態に戻したい場合は、ダウン(rollback)コマンドを使います。


migrate -path db/migrations -database "postgres://user:pass@localhost:5432/dbname?sslmode=disable" down

このコマンドで、最新のマイグレーション変更を取り消すことができます。複数ステップ戻す場合もオプションで指定可能です。

5. Go言語でのマイグレーション自動化

5. Go言語でのマイグレーション自動化
5. Go言語でのマイグレーション自動化

Goプログラム内からマイグレーションを自動化することも可能です。アプリ起動時に自動でマイグレーションを適用することで、手動作業を減らせます。


import (
    "github.com/golang-migrate/migrate/v4"
    _ "github.com/golang-migrate/migrate/v4/database/postgres"
    _ "github.com/golang-migrate/migrate/v4/source/file"
)

func main() {
    m, err := migrate.New(
        "file://db/migrations",
        "postgres://user:pass@localhost:5432/dbname?sslmode=disable")
    if err != nil {
        log.Fatal(err)
    }
    m.Up() // マイグレーションを適用
}

これにより、アプリ起動と同時に最新のデータベース構造に更新できます。特にチーム開発で便利です。

6. バージョン管理と安全な運用

6. バージョン管理と安全な運用
6. バージョン管理と安全な運用

マイグレーションはバージョン管理と密接に関連しています。各マイグレーションファイルには番号が振られ、順番通りに適用されます。Gitなどでファイルを管理することで、チーム全体で安全にデータベース構造を変更できます。

7. 注意点とベストプラクティス

7. 注意点とベストプラクティス
7. 注意点とベストプラクティス

マイグレーションを使うときは、以下の点に注意してください。
・本番環境では必ずバックアップを取る
・マイグレーションは小さく分けて作成する
・複雑な変更はテスト環境で事前に確認する

これらを守ることで、Go言語でのデータベース運用が安全かつ効率的になります。

関連記事:
カテゴリの一覧へ
新着記事
New1
Swift
SwiftPMで自作パッケージを公開する方法を完全ガイド!初心者でもわかる公開手順
New2
Kotlin
Kotlinの拡張関数をライブラリとしてまとめる方法!初心者でもできるコード再利用術
New3
Go言語
Go言語のDBアクセス層の設計パターンとベストプラクティス|初心者向け解説
New4
Kotlin
Kotlinのスコープ関数の戻り値の違いと使い分けを初心者向けに解説!
人気記事
No.1
Java&Spring記事人気No1
Go言語
Go言語のドライバ設定を完全解説!MySQL・PostgreSQLの接続手順を初心者向けにやさしく説明
No.2
Java&Spring記事人気No2
Kotlin
KotlinのChannelでデータをやり取りする方法を完全ガイド!初心者にもわかる非同期通信の基本
No.3
Java&Spring記事人気No3
Kotlin
Kotlin DSLとGroovy DSLの違いをやさしく解説!初心者でもわかるGradleスクリプトの使い分け
No.4
Java&Spring記事人気No4
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.5
Java&Spring記事人気No5
Swift
Swift UIKitとSwiftUIの違いを徹底比較!初心者はどちらを選ぶべき?
No.6
Java&Spring記事人気No6
Kotlin
Kotlinでテキスト表示・編集!初心者でもわかるTextViewとEditTextの使い方
No.7
Java&Spring記事人気No7
Kotlin
Kotlinのビルド設定エラーと解決法まとめ!初心者向けGradleトラブル対処ガイド
No.8
Java&Spring記事人気No8
Kotlin
Kotlinでデータベースのテストを行う方法を徹底解説!初心者でもわかるRoomのテスト入門

💻 作業効率アップに

ノートPCを縦置きしてデスクを広く。
省スペースで片づく定番スタンド

UGREEN 縦型スタンドをAmazonで見る

※ Amazon広告リンク