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
実践 Database Schema as Code
Search
Ken’ichiro Oyama
February 27, 2017
Technology
11
2.5k
実践 Database Schema as Code
Fukuoka.php Vol.21
Ken’ichiro Oyama
February 27, 2017
Tweet
Share
More Decks by Ken’ichiro Oyama
See All by Ken’ichiro Oyama
実践 net/http Middleware パターン / Kizuku.go Vol.1
k1low
2
240
Cleanup handling in Go / Go Conference 2024
k1low
6
3.4k
CI/CDがあたりまえの今の時代にAPIテスティングツールに求められていること / CI/CD Test Night #7
k1low
17
10k
Command-line interface tool design / PHPerKaigi 2024
k1low
8
3k
gostyle IS NOT Go Style / Fukuoka.go#19 Reboot
k1low
1
250
Parsing case study in Go / Go Conference mini 2023 Winter IN KYOTO
k1low
2
1.3k
APIシナリオテストツールとしてのrunn / 4 API testing tools
k1low
3
1.5k
The future of tbls and "Documentation as Code" / phpconfuk 2023
k1low
4
6.3k
net/http/httptest.Server のアプローチをテスト戦略に活用する / Go Conference 2023
k1low
10
3.1k
Other Decks in Technology
See All in Technology
一人から始めたSREチーム3年の歩み - 求められるスキルの変化とチームのあり方 - / The three-year journey of the SRE team, which started all by myself
vtryo
7
5.7k
Creative Pair
kawaguti
PRO
1
130
Redmineの意外と知らない便利機能 (Redmine 6.0対応版)
vividtone
0
190
Power BI は、レポート テーマにこだわろう!テーマのティア表付き
ohata_ds
0
120
アクセシブルなマークアップの上に成り立つユーザーファーストなドロップダウンメニューの実装 / 20250127_cloudsign_User1st_FE
bengo4com
2
1.2k
SREとしてスタッフエンジニアを目指す / SRE Kaigi 2025
tjun
15
6.5k
Postman Vaultを使った秘密情報の安全な管理
nagix
3
140
Tech Blog執筆のモチベート向上作戦
imamura_ko_0314
0
740
extensionとschema
yahonda
1
100
Tokyo RubyKaigi 12 - Scaling Ruby at GitHub
jhawthorn
2
210
教師なし学習の基礎
kanojikajino
4
360
顧客の声を集めて活かすリクルートPdMのVoC活用事例を徹底解剖!〜プロデザ!〜
recruitengineers
PRO
0
200
Featured
See All Featured
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
356
29k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
160
15k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
30
2.1k
Making Projects Easy
brettharned
116
6k
Visualization
eitanlees
146
15k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
251
21k
How to Think Like a Performance Engineer
csswizardry
22
1.3k
Documentation Writing (for coders)
carmenintech
67
4.6k
jQuery: Nuts, Bolts and Bling
dougneiner
63
7.6k
Building an army of robots
kneath
302
45k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
226
22k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
20
2.4k
Transcript
実践 Database Schema as Code Kenʼichiro Oyama Fusic Co.,Ltd. 2017.2.27
1 Fukuoka.php Vol.21
Who 2 Fukuoka.php Vol.21
k1LoW Kenʼichiro Oyama @k1LoW Fusic Co.,Ltd. エンジニア
基盤ユニット テックリード awspecというAWS⽤のテストツールを作っています https://github.com/k1LoW/awspec 3 Fukuoka.php Vol.21
データベーススキーマ どのように管理していますか? 4 Fukuoka.php Vol.21
データベーススキーマ CREATE TABLE, ALTER TABLE, DROP TABLE 型
物理名、論理名 リレーション 5 Fukuoka.php Vol.21
データベーススキーマの管理 例えばExcel 提出物としては良い CREATE⽂を出⼒するマクロも可能 バイナリファイルなので差分の確認がしにくい
ALTERの管理が難しい スキーマ情報の反映を忘れて過去のものになることも 例えば.sqlファイル テキストファイルとしてGit管理ができる ALTERの管理が難しい 6 Fukuoka.php Vol.21
データベーススキーマもコード で管理したい 7 Fukuoka.php Vol.21
フレームワーク フレームワークのマイグレーション機能 ALTERを都度別ファイルで管理 詳細に記述することも可能 積み上げ型
最終形のスキーマを確認しにくい 積み上げに失敗したとき修復が難しい 気づかずに失敗していることがある Phinxなども同じ 8 Fukuoka.php Vol.21
つらいぞ 9 Fukuoka.php Vol.21
我々がしたいことは何か? データベーススキーマをコードで管理したいだけ ALTERを管理したいわけではない Gitで管理できればいい テーブル履歴をファイルで管理したいわけではない
Gitで管理できればいい みんなが最終形のスキーマを⼿に⼊れられれば良い そしてそれをいい感じで適⽤できればいい 10 Fukuoka.php Vol.21
Infrastructure as Code の世界はどうか? 11 Fukuoka.php Vol.21
例えばAnsible 宣⾔的 あるべき状態を宣⾔ 可読性が⾼い べき等性
ある操作を何度実⾏しても常 に結果が同じになる [宣伝] “Ansible徹底⼊⾨” 発売中! http://www.shoeisha.co.jp/book/detail/ 9784798149943 12 Fukuoka.php Vol.21
Database Schema as Code はないのか? ※初出: https://www.slideshare.net/YoshiyukiNakahara/db-schema-ascode 13 Fukuoka.php Vol.21
そう、 Rubyistは知っている 14 Fukuoka.php Vol.21
Ridgepole 15 Fukuoka.php Vol.21
Ridgepole べき等性を持ったデータベーススキーマ管理ツ ール https://github.com/winebarrel/ridgepole ridgepole --apply コマンドを実⾏したとき、
Ridgepole は Schemafile に書かれたテーブル定義を、実際の DB に接続して DB 上のテーブル定義 と⽐較します。もし Schemafile に書かれた定義と DB 上の定義に差分が あれば、その差分だけが ALTER TABLE ⽂となって、DB に適⽤されます。 http://techlife.cookpad.com/entry/2014/08/28/194147 1ファイル(Ruby DSL)でスキーマ管理 コメントも管理できる 16 Fukuoka.php Vol.21
Schemafile 17 Fukuoka.php Vol.21 create_table “users”, comment: ”会員情報” do |t|
t.text "username", comment: "ログインユーザー" t.text "password", comment: "ログインパスワード” t.text "email", comment: "メールアドレス" t.datetime "created", comment: "登録⽇時" t.datetime "modified", comment: "更新⽇時” end
RidgepoleはPHPerこそ使うべき 18 Fukuoka.php Vol.21
RidgepoleはPHPerこそ使うべき理由 アプリケーションはRuby製ではないので、 Ridgepole専⽤のRubyを気軽に導⼊できる Railsではないので、最新のRubyで最新の Ridgepoleを気軽に導⼊できる フレームワークに関係なく、古いPHPアプリだ ろうが気軽導⼊できる
--export オプションがあるので、今からでも気 軽に導⼊できる 19 Fukuoka.php Vol.21
気軽に導⼊できる最⾼体験 20 Fukuoka.php Vol.21
Ridgepole導⼊しようぜ! 21 Fukuoka.php Vol.21
我々がしたいことは何か? データベーススキーマをコードで管理したいだけ 22 Fukuoka.php Vol.21
それだけなんだ! 23 Fukuoka.php Vol.21
...それだけでは いかない世界がある 24 Fukuoka.php Vol.21
続・我々がしたいことは何か? データベーススキーマをコードで管理したいだけ 25 Fukuoka.php Vol.21
続・我々がしたいことは何か? データベーススキーマをコードで管理したいだけ データベース設計書も欲しい(Excelで) 26 Fukuoka.php Vol.21
続・我々がしたいことは何か? データベーススキーマをコードで管理したいだけ データベース設計書も欲しい(Excelで) ER図も欲しい(いい感じのやつ) 27 Fukuoka.php Vol.21
ならば解決しよう 28 Fukuoka.php Vol.21
スキーマからの リバースエンジニアリング 29 Fukuoka.php Vol.21
A5:SQL Mk-2 30 Fukuoka.php Vol.21
A5:SQL Mk-2 http://a5m2.mmatsubara.com/ ⾼機能SQLツール 強⼒なスキーマからのリバースエンジニアリングツー ルによって
Excelなデータベース設計書を作れる コメントを論理名として認識させる設定最⾼ ER図を作れる いけそう! 31 Fukuoka.php Vol.21
...それだけでは いかない世界がある 32 Fukuoka.php Vol.21
キーレスエントリ 33 Fukuoka.php Vol.21
キーレスエントリ SQLアンチパターンの1つ データベースで外部キー制約をはっていない フレームワークの命名規則によるリレーションに頼っ ている状態 よくある
34 Fukuoka.php Vol.21
ER図は外部キー制約を設定していないと (キーレスエントリなスキーマでは) リレーションがはられない 35 Fukuoka.php Vol.21
tmpfk 36 Fukuoka.php Vol.21
tmpfk Railsライクな命名規則を読み取ってテンポラリ な外部キー制約を付けたり外したりするツール Railsライク: users と user_id とか
CakePHPもRailsライクな命名規則 LaravelもRailsライクな命名規則 https://github.com/k1LoW/tmpfk 37 Fukuoka.php Vol.21
38 Fukuoka.php Vol.21
外部キー制約を付けてER図を⽣成する と。。。 39 Fukuoka.php Vol.21
40 Fukuoka.php Vol.21 :+1:
Ridgepole導⼊しようぜ! 41 Fukuoka.php Vol.21
Thank you! Fusicはテクノロジーが 好きなエンジニアを募集しています https://fusic.github.io 42