リバースエンジニアリング(Scaffolding)
リバースエンジニアリング(スキャフォールディングによる)は、スキーマを通じて利用可能なすべてのテーブルとビューのクラスを自動的に構築することによってOR/M を合理化するプロセスです。このプロセスではCDataContext クラスも作成されます。このクラスはDbContext を拡張し、データソース内のテーブルを示すDbSet プロパティを公開します。
Entity Framework Core ツールのインストール
コンソールアプリでスキャフォールディングを利用している場合は、まずPackage Manager Console(PMC)経由でEF ツールをインストールする必要があります。
Install-Package Microsoft.EntityFrameworkCore.Tools -Version 6.0 //Run this command if using EF Core 6.0
スキャフォールディング
スキャフォールディングは、Visual Studio のPMC を使用して実行されます。スキャフォールドには以下のコマンドを使用できます。
すべてのテーブルをスキャフォールド
次のコマンドを使用して、すべてのテーブルとビューをスキーマからModels フォルダにスキャフォールドします。
Scaffold-DbContext "Port=993;Server=outlook.office365.com;Password=password;User=user;Protocol=IMAP;SMTP Port=587;SMTP Server=smtp.office365.com;" CData.EntityFrameworkCore.Email -OutputDir Models -Context EmailContext
テーブルのA サブセットをスキャフォールド
限られた範囲のテーブルに対してのみクラスを作成するようにスキャフォールドプロセスを改良することもできます。大量のクラスを生成する必要があるため大規模なスキーマのスキャフォールドに長時間かかる場合、これは特に便利です。これは、PMC のScaffold-DbContext コマンドの最後に、スキャフォールドするテーブル/ビューを指定することによって実現されます。
Scaffold-DbContext "Port=993;Server=outlook.office365.com;Password=password;User=user;Protocol=IMAP;SMTP Port=587;SMTP Server=smtp.office365.com;" CData.EntityFrameworkCore.Email -OutputDir Models -Context EmailContext -Tables [INBOX]
データモデルの更新
初期生成後に再スキャフォールドして、テーブルクラスを追加してモデルを更新したい場合は、Scaffold-DbContext コマンドに '-Force' 引数を追加するだけです。その後、既存のモデルは変更で上書きされます。