• EntityFramework6.X 之 Database Initialization


    Database Initialization

    下图是数据库初始化的工作流

                                                               

    EF为数据库初始化准备了多种策略:

    l  CreateDatabaseIfNotExists:这是默认的初始化策略

    l  DropCreateDatabaseAlways:总是创建数据库,不管数据库中是否存在数据,每次应用程序启动时就会重新设置

    l  DropCreateDatabaseIfModelChanges:有且仅当领域模型发生改变的时候创建数据库

    若要启动测试数据则必须在应用程启动的时候通过Database.SetInitializer(new DropCreateDatabaseAlways<DBContext>())来初始化。

    数据库初始化也可以继承最原始IDatabaseInitializer<>类来创建经典原始的初始化

    public class AppTestContextCustomInitializer : IDatabaseInitializer<ApplicationDbContext>{

    public void InitializeDatabase(ApplicationDbContext context){

    if (context.Database.Exists()){

    if (!context.Database.CompatibleWithModel(true)){

           context.Database.Delete();}}

      context.Database.Create();

      context.Database.ExecuteSqlCommand("CREATE TABLE GLOBAL_DATA([KEY] VARCHAR(50), [VALUE] VARCHAR(250))");}}

    可以通过配置文件来指定初始化数据库类

    在<appSettings>节点中插入一个子节点:

    <appSettings>

    <add key="DatabaseInitializerForType CodeFirstDbInitializerDemo.BlogContext,CodeFirstDbInitializerDemo"

    value="CodeFirstDbInitializerDemo.BlogContextCustomInitializer, CodeFirstDbInitializerDemo" />

      </appSettings>

    在模型中可用特性[Table(“tablename”)]指定存储的表格名称

    EF中使用DbConfiguration类可定义一个Db配置类,使其继承DbConfiguration类,然后自定义Db配置,最后具体应用到具体的DbContext类上通过DbConfigurationType特性

    如先创建一个配置类:

    public class MyConfiguration : DbConfiguration{

      public MyConfiguration(){

    SetExecutionStrategy("providerName",()=>new  SqlAzureExecutionStrategy());

    SetDefaultConnectionFactory(new LocalDbConnectionFactory("v11.0"));}}

    使用的话可以通过两种方式:

    一种通过配置文件进行:

    <entityFramework codeConfigurationType="MyNamespace.MyDbConfiguration, MyAssembly"> 
        ...Your EF config... 
    </entityFramework>

    还有一种通过特性配置:

    [DbConfigurationType(typeof(MyDbConfiguration))] 
    public class MyContextContext : DbContext 

    }
  • 相关阅读:
    燃尽的一个不便之处修改
    jquery给元素添加样式表的方法
    http协议
    春节读书
    file_get_contents(): php_network_getaddresses: getaddrinfo failed: Name or service not known
    jQuery on(),live(),trigger()
    jquery ui中的dialog,官网上经典的例子
    问题:循环元素,被选中元素个数,全选
    3.5星|《小学问》:年轻人思维与婚恋常见误区解析
    正念疗法入门介绍,作者是日籍美国正念疗法医生:3星|《高效休息法》
  • 原文地址:https://www.cnblogs.com/Terrece/p/6860302.html
Copyright © 2020-2023  润新知