美文网首页
Entity Framework 小知识(一)

Entity Framework 小知识(一)

作者: Tootwo兔 | 来源:发表于2019-05-17 13:26 被阅读0次

零、EF初始化数据库策略

上一节我们演示的是在数据库不存在的情况下操作数据库的方法,但是某些情况下数据库是已经存在的(例如:对已有系统的升级改造扩展、DBA已经将数据库提前创建等等)。那么这种情况下我们该怎么办呢?这时我们就用到了EF数据库初始化的三种策略。这三种策略如下:

  1. 如果数据库不存在,则创建,存在,则不创建
Database.SetInitializer(new CreateDatabaseIfNotExists<EfDbContext>());
  1. 不管数据库是否存在,都创建
Database.SetInitializer(new DropCreateDatabaseAlways<EfDbContext>());
  1. 如果数据库模型发生变化,更新数据库
Database.SetInitializer(new DropCreateDatabaseIfModelChanges<EfDbContext>());

注:以上三种策略需要在EF上下文派生类中的构造函数中定义。

上述三种策略是定义在代码中的,我们也可以将他们定义在配置文件中,我们以第三种策略为例,在 .config 文件中的AppSettings节点下配置:

<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>

相关文章

  • Entity Framework 小知识(一)

    零、EF初始化数据库策略 上一节我们演示的是在数据库不存在的情况下操作数据库的方法,但是某些情况下数据库是已经存在...

  • Entity Framework 小知识(二)

    零、基于代码配置 基于代码配置是EF6新增的一个特性,操作步骤如下: 创建DbConfig派生类; 配置默认连接工...

  • Entity Framework 小知识(三)

    零、乐观并发 在单服务器上运行的站点,为了防止出现脏读现象,我们一般使用Lock语句关键字,但是如果在分布式站点上...

  • Entity Framework 小知识(四)

    在EF中并没有提供包含索引和过滤索引的创建方法,那么我们就么发创建了吗?答案是否定的,我们可以通过迁移类进行创建包...

  • EF Core 学习

    Entity Framework(EF) Core Entity Framework 是一种支持 .NET 开发人...

  • Entity Framework简介

    零、什么是Entity Framework Entity Framework (简称EF),是.NET的 Obje...

  • MVC(MyStoreEntities)

    Entity Framework(EF框架) Entity Framework负责将模型与数据库关联起来 Enti...

  • Entity Framework学习笔记

    Entity Framework是一个强烈关注建模的技术。 Entity Framework有三种开发方式,分别是...

  • EF (一):Database-First

    ADO.NET Entity Framework 以 Entity Data Model (EDM) 为主,将数据...

  • Beginning Entity Framework Core

    下载地址:Beginning Entity Framework Core 2.0.pdf

网友评论

      本文标题:Entity Framework 小知识(一)

      本文链接:https://www.haomeiwen.com/subject/wknnaqtx.html