zoukankan      html  css  js  c++  java
  • 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 

    }
  • 相关阅读:
    Nginx源码编译安装与负载均衡配置实践
    jquery_file_upload in Rails(ajax实现多张图片上传)
    Nokogiri相关网站
    rails中 url和path的区别
    Unique Paths
    Kinect for windows的脸部识别
    .Net给图片添加水印效果
    大型高性能ASP.NET系统架构设计
    如何来提高网站的访问速度,其中包括服务器的配置建议,asp.NET代码的编写及前端页面的优化等等
    URL中#号(井号)的作用
  • 原文地址:https://www.cnblogs.com/Terrece/p/6860302.html
Copyright © 2011-2022 走看看