Entity Framework 小知识(一)

栏目: ASP.NET · 发布时间: 5年前

内容简介:上一节我们演示的是在数据库不存在的情况下操作数据库的方法,但是某些情况下数据库是已经存在的(例如:对已有系统的升级改造扩展、DBA已经将数据库提前创建等等)。那么这种情况下我们该怎么办呢?这时我们就用到了EF数据库初始化的三种策略。这三种策略如下:注:以上三种策略需要在EF上下文派生类中的构造函数中定义。上述三种策略是定义在代码中的,我们也可以将他们定义在配置文件中,我们以第三种策略为例,在

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

面向对象葵花宝典:思想、技巧与实践

面向对象葵花宝典:思想、技巧与实践

李运华 编著 / 电子工业出版社 / 2015-12 / 69

《面向对象葵花宝典:思想、技巧与实践》系统地讲述了面向对象技术的相关内容,包括面向对象的基本概念、面向对象开发的流程、面向对象的各种技巧,以及如何应用面向对象思想进行架构设计。在讲述相关知识或技术的时候,除了从“是什么”这个角度进行介绍外,更加着重于从“为什么”和“如何用”这两个角度进行剖析,力争让读者做到“知其然,并知其所以然”,从而达到在实践中既能正确又能优秀地应用面向对象的相关技术和技巧。 ......一起来看看 《面向对象葵花宝典:思想、技巧与实践》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具