• The model backing the <Database> context has changed since the database was created.


    Just found out the answer and thought of updating here. Just need to do the following.

    public class AddressBook: DbContext
    {
       protected override void OnModelCreating(ModelBuilder modelBuilder)
       {
        modelBuilder.IncludeMetadataInDatabase = false;
       }
    }

    以下内容引用自:http://www.cnblogs.com/libingql/p/3351275.html

    Entity Framework数据库初始化方式

    Entity Framework通过Database.SetInitializer来指定需要的数据库初始化方式,Database.SetInitializer可指定的数据库共有3种:

      1>. CreateDatabaseIfNotExists

      CreateDatabaseIfNotExists是Database.SetInitializer指定数据库的默认方式,用于当数据库不存在时,自动创建数据库。由于该方式是默认方式,所以可以不需要任何代码进行指定,当然也可以使用代码来明确的指定。

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

      2>. DropCreateDatabaseWhenModelChanges

      DropCreateDatabaseWhenModelChanges用于当数据模型发生改变时,先删除原数据库,后创建新的数据库。

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

      3>. DropCreateDatabaseAlways

      DropCreateDatabaseAlways用于每次均先删除原数据库再创建新的数据库,不管数据模型是否发生改变。

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

      但是,在很多时候,我们希望即使在Entity Framework Code First与数据库不匹配时,宁可Entity Framework Code First报出数据库连接错误,而不希望对数据库进行任何的删除创建操作。Entity Framework Code First提供关闭数据库初始化操作:

    Database.SetInitializer<PortalContext>(null);
  • 相关阅读:
    第一课:数据库介绍篇
    爬虫day03 cast
    python excel
    爬虫 cast_day05_多进程_多线程_协程_selenium的使用
    进程_线程_协程回顾!
    进程_线程_协程回顾 2!
    day 06 爬虫
    看正月点灯笼老师的笔记 —动态规划2.1
    动态规划——放苹果

  • 原文地址:https://www.cnblogs.com/dupeng0811/p/the-model-backing-the-database-context-has-changed-since-the-database-was-create.html
Copyright © 2020-2023  润新知