解決Code First因_migrationHistory表與代碼不一致的問題

  咱們在測試環境多人開發時,因爲會存在多個測試、開發環境,可是你們共用一個數據庫。數據庫

  這時候會碰到一個問題,一旦有某我的經過Migration更新了數據庫,其餘環境在首次查詢數據庫的時候都會收到Dbcontext與代碼不一致的錯誤,提示須要作Migration的錯誤。可是其餘人的代碼極可能都沒有簽入到服務器,因此根本沒法得到Migration的記錄。遇到這種狀況須要關閉Codefirst對數據庫的檢測代碼中增長:編程

Database.SetInitializer<testContext>(null);

  更多內容:服務器

Code first數據庫初始化的4種策略,其中第四種就不會檢查_migrationHistory的記錄app

策略一:數據庫不存在時從新建立數據庫ide

Database.SetInitializer<testContext>(new CreateDatabaseIfNotExists<testContext>());

策略二:每次啓動應用程序時建立數據庫函數

Database.SetInitializer<testContext>(new DropCreateDatabaseAlways<testContext>());

策略三:模型更改時從新建立數據庫測試

Database.SetInitializer<testContext>(new DropCreateDatabaseIfModelChanges<testContext>());

策略四:從不建立數據庫ui

Database.SetInitializer<testContext>(null);

Entity Framework數據庫初始化示例

spa

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中DbContext首次加載OnModelCreating會檢查__MigrationHistory表,做爲使用Code Frist編程模式,而實際先有數據庫時,這種檢測就是多餘的了,因此須要屏蔽,在EF 4.1以前可使用在OnModelCreating函數總加入下面語句來屏蔽這種檢測:code

modelBuilder.Conventions.Remove<IncludeMetadataConvention>();

 

而到4.3以後須要使用,上列語句以被MSDN明確表示過期,因此須要新的方式取代:

Database.SetInitializer<DBContext>(null);
相關文章
相關標籤/搜索