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
FluentMigratorでDBマイグレーション
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
thinkAmi
February 21, 2015
Programming
0
2.3k
FluentMigratorでDBマイグレーション
2015/2/21に開かれた、めとべや東京 #7 でのLTスライドです。
thinkAmi
February 21, 2015
Tweet
Share
More Decks by thinkAmi
See All by thinkAmi
知ろう!使おう!HDF5ファイル!/pycon-jp-2019-talk
thinkami
5
11k
Djangoでのメール送信 - 設定からテストまで/djangocongress-jp-2019-talk
thinkami
1
13k
Django・WSGIミドルウェア入門/django-congress-jp-2018-talk
thinkami
4
5.5k
自分のための機械学習をしてみた話
thinkami
0
660
Xamarinで作るAndroid Wearアプリ
thinkami
1
2.7k
デプロイボタンを使ってみた
thinkami
0
1.1k
Vagrant + Berkshelf でお手軽写経環境構築
thinkami
1
1.4k
Twilio入門
thinkami
0
1.7k
おひとりさま環境でのChef-solo使用例
thinkami
2
1.5k
Other Decks in Programming
See All in Programming
[KNOTS 2026登壇資料]AIで拡張‧交差する プロダクト開発のプロセス および携わるメンバーの役割
hisatake
0
280
OSSとなったswift-buildで Xcodeのビルドを差し替えられるため 自分でXcodeを直せる時代になっている ダイアモンド問題編
yimajo
3
620
AI Agent の開発と運用を支える Durable Execution #AgentsInProd
izumin5210
7
2.3k
CSC307 Lecture 08
javiergs
PRO
0
670
HTTPプロトコル正しく理解していますか? 〜かわいい猫と共に学ぼう。ฅ^•ω•^ฅ ニャ〜
hekuchan
2
690
0→1 フロントエンド開発 Tips🚀 #レバテックMeetup
bengo4com
0
570
Spinner 軸ズレ現象を調べたらレンダリング深淵に飲まれた #レバテックMeetup
bengo4com
1
230
Package Management Learnings from Homebrew
mikemcquaid
0
220
フロントエンド開発の勘所 -複数事業を経験して見えた判断軸の違い-
heimusu
7
2.8k
CSC307 Lecture 09
javiergs
PRO
1
840
izumin5210のプロポーザルのネタ探し #tskaigi_msup
izumin5210
1
130
AI時代の認知負荷との向き合い方
optfit
0
160
Featured
See All Featured
How to Ace a Technical Interview
jacobian
281
24k
A better future with KSS
kneath
240
18k
Why Our Code Smells
bkeepers
PRO
340
58k
Ethics towards AI in product and experience design
skipperchong
2
190
Building the Perfect Custom Keyboard
takai
2
680
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
60
42k
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
2
190
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
730
Producing Creativity
orderedlist
PRO
348
40k
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
1
1.4k
Rails Girls Zürich Keynote
gr2m
96
14k
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
1
53
Transcript
FluentMigratorで DBマイグレーション @thinkAmi めとべや東京 #7 2015.2.21
自己紹介 • 長野県から来ました • アカウント – thinkAmi • Twitter •
Hatena • GitHub • C#(WPF)とかMS AccessとかRubyとか
自己紹介 • りんご食べあるき – 現在57種類くらい • 今日はピンクレディを食べました • Twitter +
Heroku + C#(Ruby)で記録・公開 » http://ringo-tabetter-cs.herokuapp.com/
長野県のコミュニティ • NSEG (#nseg) – 長野県とコンピューターをテーマに毎月開催 • 本日、ギークラボ長野でOpenDataハッカソン中 • Google
Developer Group 信州 • 3/14 AndroidWearイベント » IT勉強会スタンプラリー参加 • Azure しなの (3/28 Hokuriku.NETと合同勉強会) • JAWS-UG 長野支部 » 他のコミュニティ > https://github.com/nseg- jp/w/wiki/NSEG以外の長野のIT勉強会
本題 • FluentMigratorでDBマイグレーション • クライアントアプリの裏側ということで...
定義 • DBマイグレーションとは – DBのテーブルスキーマの更新などを管理・実 行できるようにすること – 他にもありますが、今回は上記の定義です
本題 • データベースの管理にて – 最初のうち • CUIでDDLやDMLを実行 • GUIでポチポチ –
次第に忘れ去られ... • どの順番でどのDDLやDMLを実行する? • 何でこんなスキーマにしたんだっけ? » ツライ – DBマイグレーションをしたい...
Entity Framework • Code First Migrations – MS Accessで試したが使えず... •
EFがOLEDB接続をサポートしていないため » http://stackoverflow.com/a/11197393
FluentMigrator • DBマイグレーションフレームワーク – C#で、DDLやDMLを書く • DBに依存せず、スキーマの変更を記述可能 • Gitなどで、バージョン管理可能 •
リポジトリ(GitHub) – https://github.com/schambers/fluentmigrator • 830starほど • Apache 2 License
動作RDBMS • SQL Server • SQL Server Compact Edition •
PostgreSQL • MySQL • Oracle • SQLite • Jet (MS Access, ACEも動作) » https://github.com/schambers/fluentmigrator /wiki/Fluent-Interface
実行方法 • コマンドライン • NAnt • MSBuild • Rake –
Ruby + Albacore gem が必要 » https://github.com/schambers/fluentmigrator /wiki/Migration-Runners
インストール • NuGetでインストール – 本体 • PM> Install-Package FluentMigrator –
コマンドラインランナーを使う場合 • PM> Install-Package FluentMigrator.Tools
マイグレーションファイル • コード
マイグレーションの実行 • 実行 .\Migrate.exe --assembly=FluentMigrationTest.exe --provider=jet --connection="Provider=Microsoft.ACE.OLEDB.12.0;DataSo urce=D:\db\targetdb.accdb" --verbose=True --task=migrate
実行結果の表示 CREATE TABLE [hoge] ([id] COUNTER NOT NULL, [content] VARCHAR(255),
CONSTRAINT [PK_hoge] PRIMARY KEY ([id]))
MS Accessの結果 • DDLが実行されている
マイグレーション(DDL) • CREATE TABLE Create.Table("hoge") .WithColumn("id") .AsInt32() .PrimaryKey().Identity() .WithColumn("content") .AsString().Nullable();
マイグレーション(DDL) • ALTER TABLE Alter.Table("hoge") .AddColumn("fuga") .AsString().Nullable() .AlterColumn("content") .AsString().NotNullable();
マイグレーション(DDL) • CREATE INDEX Create.Index("idx") .OnTable("hoge") .OnColumn("content");
マイグレーション(DDL) • RENAME COLUMN Rename.Column("fuga") .OnTable("hoge") .To("piyo");
マイグレーション(DML) • INSERT Insert.IntoTable("hoge") .Row(new { content = "added" });
• UPDATE Update.Table("hoge") .Set(new { content = "updated" }) .Where(new { id = 1 });
ランナーのオプション – assembly » 対象のマイグレーションが含まれるexe/dll – provider » 対象のRDBMS –
connection (接続文字列) – task » Migration, Rollback(全件, 1件, 指定ver etc) – verbose » Trueでマイグレーションの詳細を表示
クラウド(Paas)での実行 • Azure Websites – 管理画面(Kudu)のConsoleにて • Heroku – Third-Party
Buildpacksでビルド • Monoでのビルド – friism/heroku-buildpack-mono – heroku/dotnet-buildpack (ASP.NET 5用?) – One-Off Dynos でHeroku Postgresへ実行 • heroku run bash 後
まとめ • FluentMigratorを使えば、EFを使えない 環境でもDBマイグレーション可能 • 他のDBマイグレーションツールがあれば 知りたいです!
参考文献など • 参考文献 – FluentMigrator公式Wikiが一番参考になります • https://github.com/schambers/fluentmigrator/wiki • スライドまわり –
プレゼンツール • Rabbit (Ruby製) – http://rabbit-shocker.org/ja/ – スライドテンプレート • 交差点の真ん中で様のパワーポイント用自作デザインテンプレート – http://sagittarius.dip.jp/toshi/template.php – フォント • フォントな様のやさしさゴシックボールド – http://www.fontna.com/blog/736/