Entity Framework数据库初始化四种策略
Posted Avatarx
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Entity Framework数据库初始化四种策略相关的知识,希望对你有一定的参考价值。
策略一:数据库不存在时重新创建数据库
复制内容到剪贴板 程序代码
Database.SetInitializer<testContext>(new CreateDatabaseIfNotExists<testContext>());
策略二:每次启动应用程序时创建数据库
复制内容到剪贴板 程序代码
Database.SetInitializer<testContext>(new DropCreateDatabaseAlways<testContext>());
策略三:模型更改时重新创建数据库
复制内容到剪贴板 程序代码
Database.SetInitializer<testContext>(new DropCreateDatabaseIfModelChanges<testContext>());
策略四:从不创建数据库
复制内容到剪贴板 程序代码
Database.SetInitializer<testContext>(null);
Entity Framework数据库初始化示例
复制内容到剪贴板 程序代码
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using Web.Models.Mapping;
namespace Web.Models
{
public class testContext : DbContext
{
static testContext()
{
Database.SetInitializer<testContext>(null);
}
public testContext()
: base("Name=testContext")
{
}
public DbSet<Person> People { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Configurations.Add(new PersonMap());
}
}
}
using System.Data.Entity.Infrastructure;
using Web.Models.Mapping;
namespace Web.Models
{
public class testContext : DbContext
{
static testContext()
{
Database.SetInitializer<testContext>(null);
}
public testContext()
: base("Name=testContext")
{
}
public DbSet<Person> People { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Configurations.Add(new PersonMap());
}
}
}
以上是关于Entity Framework数据库初始化四种策略的主要内容,如果未能解决你的问题,请参考以下文章
Entity Framework(code first)数据库初始化
227 Mapped 类的子类型导致Entity framework 数据库上下文初始化缓慢?