上一节咱们演示的是在数据库不存在的状况下操做数据库的方法,可是某些状况下数据库是已经存在的(例如:对已有系统的升级改造扩展、DBA已经将数据库提早建立等等)。那么这种状况下咱们该怎么办呢?这时咱们就用到了EF数据库初始化的三种策略。这三种策略以下:数据库
Database.SetInitializer(new CreateDatabaseIfNotExists<EfDbContext>());
Database.SetInitializer(new DropCreateDatabaseAlways<EfDbContext>());
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派生类),逗号后面是派生类所在的命名空间。
某些状况下咱们不须要使用EF的数据库初始化策略,这时咱们能够在代码或配置文件中设置,以下:函数
Database.SetInitializer<EfDbContext>(null);
注:以代码方式禁用初始化策略,也学要在EF上下文派生类中的构造函数中定义
<appSettings> <add key="DatabaseInitializerForType _2_1Code.EfDbContext,_2_1Code" value="Disabled"/> </appSettings>