Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
SQLだけでマイグレーションしたい!
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
MakKi
December 19, 2025
Technology
1.4k
0
Share
SQLだけでマイグレーションしたい!
MyNA望年LT大会2025
MakKi
December 19, 2025
More Decks by MakKi
See All by MakKi
テストだけじゃない!インプロセスDBで生まれるGoらしさ
makki_d
0
47
テストだけじゃない!インプロセスDBで生まれるGoらしさ
makki_d
0
57
Recap: An Operating System in Go
makki_d
2
160
XSLTで作るBrainfuck処理系
makki_d
0
380
眼鏡と視力についての誤解を解く
makki_d
0
220
標準ライブラリの動向とイテレータのパフォーマンス
makki_d
3
770
range over funcのエラー処理
makki_d
1
1.8k
GoとテストとインプロセスDB
makki_d
3
690
君は古の言語M4を知っているか (LT)
makki_d
0
570
Other Decks in Technology
See All in Technology
Agentic AI時代における メルカリのAIガバナンスとガードレール実装
naoichihara
16
16k
layerx-fde-practices
cipepser
6
2.8k
JICUG あなたのAI駆動開発パートナー IBM Bob を使ったアプリ開発
1ftseabass
PRO
0
110
まだ道半ば、AI-DLCを歩み始めている話
news_it_enj
2
210
APIテストとは?
nagix
0
130
Typiaで配信JSONの安全性を構造的に担保する(TSKaigi2026)
righttouch
PRO
1
190
Fabric-cicd によるAzure DevOps デプロイ
ryomaru0825
0
100
Spring AI × MCP 入門〜AIエージェントへのツール公開、境界設計から始める最小構成 〜
yuyamiyamoto
0
150
大学生が本気でDatabricksを活用してDiscordサークルをデータ駆動させてみた
phantomjuju
0
250
なぜハノーバーメッセに行くべきなのか 〜初参加だから語れること〜
tanakaseiya
0
160
イベントストーミングとKiroの仕様駆動開発で実現する要件の認識合わせプロセス
syobochim
7
840
Kaggle未経験社員をメダリストに育てる「AIドラゴン桜」
lycorptech_jp
PRO
0
640
Featured
See All Featured
Into the Great Unknown - MozCon
thekraken
41
2.5k
Measuring & Analyzing Core Web Vitals
bluesmoon
9
830
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.7k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
Building Applications with DynamoDB
mza
96
7k
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.3k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
160
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
180
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
230
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
16k
Keith and Marios Guide to Fast Websites
keithpitt
413
23k
Transcript
SQLだけで マイグレーションしたい! MyNA望年LT大会2025
はじめまして • 牧内大輔(MakKi) ◦ @makki_d ◦ makiuchi-d • KLab株式会社 ◦
スマホゲーム、主にサーバサイドや同期通信まわり ◦ DBはだいたいAurora MySQL • OSS ◦ gozxing: バーコードQRコードリーダーライター ◦ arelo: 自動リロードユーティリティ ◦ EMLauncher: スマホでバッグアプリ配信 ◦ WSNet2: スマホゲーム同期通信ライブラリ
https:/ /github.com/makiuchi-d/migy
• スキーマの変更を管理・適用する仕組み ◦ 状態を進めたり(Up)戻したり(Down) • いろいろなツールがある ◦ 独立したツールだったり ORMやフレームワークに付属することも •
DSLやORMの構文で記述する場合もある DBのマイグレーション
DSLとかORMとか…… こんなふうに思ったこと ありますよね?
SQLで書いたほうがはやい!!
データのコピーを伴うテーブル作成 • カラムを別テーブルに切り出す場合など • ORMでやると……SELECTして1件1件INSERT • SQLなら: INSERT INTO new_table
(id, col) SELECT id, col FROM old_table
オンラインでインデックス追加 • 長時間のロックを避けたい • M3 Tech Blog でも話題に ◦ 巨大テーブルにインデックスを追加したい、
Flywayで ◦ PostgresSQLの CREATE INDEX CONCURRENTLY • MySQLなら: CREATE INDEX … ALGORITHM=INPLACE, LOCK=NONE
マイグレーションもぜんぶ SQLで書きたい!
SQLで記述するマイグレーションツール • Flyway, Goose, … など • 自由なSQLが書ける • 適用履歴の管理などをしてくれる
SQLの整合性は管理してくれない (Up/Downの可逆性とか)
https:/ /github.com/makiuchi-d/migy
可逆性チェック • MySQL互換のDBエンジンを内蔵 ◦ go-mysql-server ◦ インプロセスDBとしてスタンドアロンで動作、 DBサーバ不要 1. チェックしたいマイグレーションの直前まで全部適用
2. スナップショット記録 3. UpのSQLを適用 4. DownのSQLを適用 5. スナップショットと現状を比較
可逆性チェック:スキーマ不一致 • テーブルの構造の一致しない部分を Diff表示 $ migy check applying: 000000_init.all.sql applying:
000010_create.up.sql ---- up/down applying: 000020_alter_add.up.sql applying: 000020_alter_add.down.sql checking... create table "table1" differs: ... `val` text NOT NULL DEFAULT '', + `val2` int DEFAULT '0', PRIMARY KEY (`id`) ... check failed
可逆性チェック:レコード不一致 • レコードの差分も検出(特定のカラムの違いは無視する指定も可能) $ migy check applying: 000030_insert.all.sql ---- up/down
applying: 000040_alter_drop.up.sql applying: 000040_alter_drop.down.sql checking... records in "table1" differs: (1, 'aaa', 10) -(2, 'bbb', 20) -(3, 'ccc', 30) +(2, 'aaa', 20) +(3, 'aaa', 30) check failed
SQLだけで完結する履歴管理 • ボイラープレート生成 ◦ Up: 履歴テーブルへの INSERT文 ◦ Down: 履歴の存在チェックと
DELETE文 • 本番サーバにツール不要 ◦ migyで列挙したSQLファイルをmysqlコマンドに流し込む ▪ .mylogin.cnf を活用できる -- Generated by migy (https://github.com/makiuchi-d/migy) INSERT INTO _migrations (id, title, applied) VALUES (10, 'user_table', now()); -- Write your forward migration SQL statements below. -- Generated by migy (https://github.com/makiuchi-d/migy) CALL _migration_exists(10); DELETE FROM _migrations WHERE id = 10; -- Write your rollback SQL statements below. user_table.up.sql user_table.down.sql
スナップショット( dump)生成 • マイグレーション適用済みの SQLダンプファイルを生成 ◦ Upを順に適用して出力 ◦ ALTERの積み重ねが適用済み •
テーブルの最新状態がわかる • 新規環境セットアップが迅速に
詳しくは技術同人誌に • KLab Tech Book Vol. 16 ◦ SQLによるDBマイグレーションの再設計 •
技術書典オンラインマーケット • 電子版無料
https:/ /github.com/makiuchi-d/migy