リバースエンジニアリング(Scaffolding)
リバースエンジニアリング(スキャフォールディングとも呼ばれる)は、DB2 スキーマからコンテキストクラスとエンティティクラスを自動生成することで、EF Core モデルの作成を効率化します。 これには、DbContext を拡張し、利用可能なテーブルとビューを表すDbSet プロパティを公開するCData Context クラスを含みます。
スキャフォールディング
スキャフォールディングは、Visual Studio のパッケージマネージャーコンソール(PMC)を使用して実行されます。 以下のコマンドは、ライブDB2 データソースからEF Core モデルをスキャフォールディングする方法を示しています。
すべてのテーブルのスキャフォールディング
次のコマンドを使用して、すべてのテーブルとビューをModels フォルダにスキャフォールディングします。
Scaffold-DbContext "Server=10.0.1.2;Port=50000;User=admin;Password=admin;Database=test" CData.EntityFrameworkCore.DB2 -OutputDir Models -Context DB2Context
テーブルのサブセットのスキャフォールディング
スキャフォールディングプロセスを絞り込んで、限られた範囲のテーブルに対してのみクラスを作成することができます。
これは、大規模なスキーマで生成する必要があるクラス数が多いためにスキャフォールディングに長時間かかる場合に便利です。
これは、PMC のScaffold-DbContext コマンドの最後に、スキャフォールドするテーブル/ビューを指定することによって実現されます。
Scaffold-DbContext "Server=10.0.1.2;Port=50000;User=admin;Password=admin;Database=test" CData.EntityFrameworkCore.DB2 -OutputDir Models -Context DB2Context -Schema DB2INST1 -Tables Books
データモデルの更新
更新されたテーブルやスキーマの変更で既存のモデルを更新するには、スキャフォールディングコマンドに-Force 引数を追加します。 これにより、以前に生成されたモデルファイルが上書きされます。