コードファーストアプローチ
本製品 からモデルを確認するもう1つの方法は、モデルクラスを記述することです。これは、Entity Framework におけるコードファーストアプローチで、アプリケーションで使用するデータモデルをより詳細に制御することができます。
コンテキストクラスの作成
これは、DbContext を拡張し、データソース内のテーブルを示すDbSet プロパティを公開する基本オブジェクトです。OnConfiguring メソッドをオーバーライドして、DbContext クラスの一部のデフォルト機能をオーバーライドします。
using Microsoft.EntityFrameworkCore; public class MYOBContext : DbContext { public DbSet<MyTable> MyTable { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { if (!optionsBuilder.IsConfigured) { optionsBuilder.UseMYOB(" If using an online instance: InitiateOAuth=GETANDREFRESH;OAuthClientId=YourClientId;OAuthClientSecret=YourClientSecret;CompanyFileId=yourCompanyFileId;CallbackURL=http://localhost:33333;User=companyFileUser;Password=companyFilePassword; If using an on premise instance: InitiateOAuth=OFF;URL=http://localhost:8080/accountright;CompanyFileId=327eed10-9615-4e5e-bd9e-ae2cc00e2c70;User=companyFileUser;Password=companyFilePassword;"); } } }
テーブルモデルの作成
コンテキストクラスのDbSet プロパティで定義された各テーブルのクラスを定義します。テーブルクラスには、そのテーブルの各フィールドに対応するプロパティのリストが含まれている必要があります。テーブルクラスの各プロパティの属性を設定するには、対応するマップクラスを定義する必要があります。
public class MyTable { public string KeyColumn { get; set; } public string MyColumn { get; set; } }
レコードの取得
以下のように、テーブルからレコードを取得します。
class Program { static void Main(string[] args) { MYOBContext context = new MYOBContext();var Query = from MyTable in context.MyTableselect MyTable; foreach (var result in Query) { Console.WriteLine("{0}", result.KeyColumn); Console.WriteLine("{0}", result.MyColumn); } try { context.SaveChanges(); } catch (Exception e) { Console.WriteLine(e); } Console.ReadLine(); } }
レコードの挿入
以下のように、既存のテーブルにレコードを挿入します。
class Program { static void Main(string[] args) { MYOBContext context = new MYOBContext(); MyTable newRecord = new MyTable() { MyColumn1 = "Value1", MyColumn2 = "Value2" }; context.Accounts.Add(newRecord); try { context.SaveChanges(); Console.WriteLine(newRecord.Id); } catch (Exception e) { Console.WriteLine(e); } Console.ReadLine(); } }