zoukankan      html  css  js  c++  java
  • Entity Framework 小知识(一)

    零、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>
    
  • 相关阅读:
    关于10053 trace中的UNCOMPBKTS和ENDPTVALS
    12c新特性
    ORA600:[ksnpost:ksnigb]错误一例
    RAC CRS Resource资源的生命周期
    Windows上如何禁用TCP/IP自动调优特性
    11g新特性
    Exadata V2 OracleSun Database Machine数据库一体机
    Script:verify Oracle Object timestamp discrepancy
    Grid Control OMS Agent代理工作原理图
    Android 编程下报错 Exception raised during rendering: java.util.LinkedHashMap.eldest()Ljava/util/Map$Entry;
  • 原文地址:https://www.cnblogs.com/gangzhucoll/p/12778211.html
Copyright © 2011-2022 走看看