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());
        }
    }
}

以上是关于Entity Framework数据库初始化四种策略的主要内容,如果未能解决你的问题,请参考以下文章

Entity Framework数据库初始化

Entity Framework(code first)数据库初始化

Entity Framework 全面教程详解(转)

227 Mapped 类的子类型导致Entity framework 数据库上下文初始化缓慢?

如何处置 Entity Framework Core 内存数据库

在 Entity Framework 4.3 中增量播种数据的最佳方法