Entity Framework 小知識(一)

零、EF初始化數據庫策略

上一節咱們演示的是在數據庫不存在的狀況下操做數據庫的方法,可是某些狀況下數據庫是已經存在的(例如:對已有系統的升級改造擴展、DBA已經將數據庫提早建立等等)。那麼這種狀況下咱們該怎麼辦呢?這時咱們就用到了EF數據庫初始化的三種策略。這三種策略以下:數據庫

  1. 若是數據庫不存在,則建立,存在,則不建立
Database.SetInitializer(new CreateDatabaseIfNotExists<EfDbContext>());
  1. 無論數據庫是否存在,都建立
Database.SetInitializer(new DropCreateDatabaseAlways<EfDbContext>());
  1. 若是數據庫模型發生變化,更新數據庫
Database.SetInitializer(new DropCreateDatabaseIfModelChanges<EfDbContext>());
注:以上三種策略須要在EF上下文派生類中的構造函數中定義。

上述三種策略是定義在代碼中的,咱們也能夠將他們定義在配置文件中,咱們以第三種策略爲例,在 .config 文件中的AppSettings節點下配置:app

<appSettings>
  <add key="DatabaseInitializerForType _2_1Code.EfDbContext,_2_1Code" value="System.Data.Entity.DropCreateDatabaseIfModelChanges,EntityFramework"/>
</appSettings>
注:DatabaseInitializerForType 後面是派生類的位置(命名空間.DbContext派生類),逗號後面是派生類所在的命名空間。

1、禁用初始化策咯

某些狀況下咱們不須要使用EF的數據庫初始化策略,這時咱們能夠在代碼或配置文件中設置,以下:函數

Database.SetInitializer<EfDbContext>(null);
注:以代碼方式禁用初始化策略,也學要在EF上下文派生類中的構造函數中定義
<appSettings>
  <add key="DatabaseInitializerForType _2_1Code.EfDbContext,_2_1Code" value="Disabled"/>
</appSettings>
相關文章
相關標籤/搜索