原文:https://msdn.microsoft.com/en-us/data/jj592674

应该选择CodeFirst、ModelFirst还是databaseFirst网上已经很多资料了,这里不多说。

本文主要包含了EF怎样发现使用哪个数据库连接,以及怎样改变它。模型可以用CodeFirst和EF设计器创建。

通常,EF应用程序会有一个继承自DbContext的类,这个继承的类调用基类DbContext的一个构造函数,EF应用程序就是利用这个类(本文中也称为上下文类)来控制下面的内容:

1、Context怎样连接到一个数据库——例如Connection string 怎样被发现和使用

2、Context是用 CodeFirst创建一个模型还是用EF设计器创建一个模型

3、其他高级选项

  • 使用CodeFirst的约定连接(按照EF约定创建连接)

如果在应用程序中没有做任何配置,那么调用DbContext的无参数构造函数时会使用CodeFirst模式按照约定来创建一个数据库及其连接。这个约定就是:数据库名称由 上下文类所在的命名空间+"."+上下文类名称。例如:

namespace Demo.EF 



    
public class BloggingContext : DbContext 

    


        
public BloggingContext() 

        
// C# will call base class parameterless constructor by default 

        


        


    


}

这个例子中,会在SQL Express或者Loacl Db中创建一个使用"Demo.EF.BloggingContext"作为数据库名的数据库,其中“Demo.EF”是上下文类所在的命名空间,“BloggingContext”是上下文类的名称。 这时,你去查看配置文件发现,没有增加任何与数据库连接相关的字符串信息。事实上,EF默认去本机查找SQLExpress或者LocalDb中名字为"Demo.EF.BloggingContext"的数据库。

VS2010中默认安装的SQL Express,VS2012中默认安装的是LocalDb,如果SQL Express和LocalDb都安装的话,那么EF会选择在SQL Express中创建数据库。

  • 使用CodeFirst的约定连接并指定数据库名称

如果在应用程序中没有做任何配置,那么调用构造函数时,可以给它一个string类型的参数,这样将建立一个以该参数为名字的数据库。例如:

public class BloggingContext : DbContext 



    
public BloggingContext(): base("BloggingDatabase") 

    


    


}

例子中将在SQL Express或者LocalDb中创建名称为"BloggingDatabase"的数据库。同样,如果SQL Express和LocalDb都安装的话,那么EF会选择在SQL Express中创建数据库。

  • 使用CodeFirst及配置文件中的connection string

你也可以选择先先在配置文件中设置好connection string。例如:

<configuration> 

  
<connectionStrings> 

    
<add name="BloggingCompactDatabase" 

         
providerName="System.Data.SqlServerCe.4.0" 

         
connectionString="Data Source=Blogging.sdf"/> 

  
</connectionStrings> 

</configuration>

然后,创建数据库上下文时使用下面的代码:

public class BloggingContext : DbContext 



    
public BloggingContext(): base("BloggingCompactDatabase") 

    


    


}

此时,创建数据库时,就会使用ConnectionString中指定的服务器和数据库名字。

你会发现这里创建数据库上下文的代码与上一节的非常相似,除了参数名字不一样。事实上,上面一段代码执行的时候,EF首先查找配置文件中有没有以“BloggingCompactDataBase”命名的连接字符串,如果有则使用该连接字符串,连接数据库(数据库未创建时会自动创建)。如果没有,那么会在SQLExpress或者LocalDb中名创建数名为“BloggingCompactDataBase”的数据库。

或者,也可以用“name=<connection string name>” 作为基类DbContext的构造函数的参数。例如:

public class BloggingContext : DbContext 



    
public BloggingContext() 

        
: base("name=BloggingCompactDatabase") 

    


    


}

注意:这种形式明确说明需要在配置文件中找到名字为“BloggingCompactDataBase”的连接字符串,如果没有找到,则会抛出异常。

  • 使用Database/Model First 及配置文件中的连接字符串

ModelFirst与CodeFirst不同,Models通过EF设计器创建,Models通常以EMDX文件的存在。

设计器会添加一个EF连接字符串到配置文件中。这个连接字符串比较特殊,它包括怎样从EDMX文件中获取信息。例如:

<configuration>  

  
<connectionStrings>  

    
<add name="Northwind_Entities"  

         
connectionString="metadata=res://*/Northwind.csdl|  

                                    
res://*/Northwind.ssdl|  

                                    
res://*/Northwind.msl;  

                           
provider=System.Data.SqlClient;  

                           
provider connection string=  

                               
&quot;Data Source=.\sqlexpress;  

                                     
Initial Catalog=Northwind;  

                                     
Integrated Security=True;  

                                     
MultipleActiveResultSets=True&quot;"  

         
providerName="System.Data.EntityClient"/>  

  
</connectionStrings>  

</configuration>

EF设计器会生成下面的代码,其中通过传递连接字符串的名字来告诉DbContext使用这个连接字符串。

public class NorthwindContext : DbContext 



    
public NorthwindContext() 

        
: base("name=Northwind_Entities") 

    


    


}

DbContext就会装入已经存在的model,而不是使用CodeFirst从code中计算,因为连接字符串是一个EF Connection string,其中包含了使用的model的细节。

  • DbContext的其他构造函数选择

DbContext类包含其他构造函数和使用模式,适用于一些更复杂的场景。具体可以参看原文,

Entity Framework(1)——Connections and Models的更多相关文章

  1. MVC & Entity Framework(2)- controller、Models单独DLL

    继上一篇MVC & Entity Framework(1)- 开发环境之后,已经很久没更新了.接下来记录一下怎么把MVC中的controller单独拆为一个类库,然后在web项目中引用.另外, ...

  2. LINQ之路10:LINQ to SQL 和 Entity Framework(下)

    在本篇中,我们将接着上一篇“LINQ to SQL 和 Entity Framework(上)”的内容,继续使用LINQ to SQL和Entity Framework来实践“解释查询”,学习这些技术 ...

  3. LINQ之路 9:LINQ to SQL 和 Entity Framework(上)

    在上一篇中,我们从理论和概念上详细的了解了LINQ的第二种架构“解释查询”.在这接下来的二个篇章中,我们将使用LINQ to SQL和Entity Framework来实践“解释查询”,学习这些技术的 ...

  4. MVC & Entity Framework(1)- 开发环境

    一直都有接触asp.net mvc,希望自己借此次机会把Blog搭起来的同时能够更深入地学习相关知识. ①新建 打开VS2012,新建ASP.Net MVC 4项目,接着选择“空”模板(因为不想用自带 ...

  5. Entity Framework(一) 映射

    ADO.NET Entity Framework通过Modeel First和DataBase First,提供了几个把数据库表映射到对象上的曾.通过Database First,可以从一个数据库架构 ...

  6. Entity Framework(六):数据迁移

    在前面的几篇文章中,简单的介绍了如何使用Entity Framework的Code First模式创建数据库,但是,在前面的几篇文章中,我们都是通过使用数据库初始化策略来做,也就是每次先删除数据库然后 ...

  7. Entity Framework(二)

    1. ORM :Object Relation Mapping ,通俗说:用操作对象的方式来操作数据库. 2. 插入数据不再是执行Insert,而是类似于 Person p=new Person() ...

  8. Chapter1-data access reloaded:Entity Framework(上)

    本章包括以下几个部分: 1.DataSet and classic ADO.NET approach2.Object model approach3.Object/relational mismatc ...

  9. Entity Framework(序)

    ADO.NET Entity Framework 是一个对象-关系的映射结构,它提供了ADO.NET的一个抽象,可基于引用的数据库获取对象模型.可以通过Entity Framework 使用不同的变成 ...

随机推荐

  1. 机器学习中的范数规则化之 L0、L1与L2范数

    http://blog.csdn.net/zouxy09/article/details/24971995/ L1正则化及其推导 Laplace(拉普拉斯)先验与L1正则化 今天我们聊聊机器学习中出现 ...

  2. Elasticsearch教程(七) elasticsearch Insert 插入数据(Java)

    首先我不赞成再采用一些中间件(jar包)来解决和 Elasticsearch  之间的交互,比如 Spring-data-elasticsearch.jar 系列一样,用就得依赖它.而 Elastic ...

  3. RPC接口mock测试

    转载:http://blog.csdn.net/ronghuanye/article/details/71124127 1        简介 Dubbo目前的应用已经越来越广泛.或者基于Dubbo二 ...

  4. Troubles in Building Android Source Code

    Some Troubles or problems you may encounter while you setup the Android source code build environmen ...

  5. Warning: isMounted(...) is deprecated in plain JavaScript React classes.

    1.错误提示 警告:isMounted(…)在纯 react.js 类中被弃用. 2.原因解析 出现此错误提示的原因是源代码内有已被React舍弃的代码,但此并不影响程序运行. 在index.js 内 ...

  6. Linux shell快捷键

    Ctrl + a 可以快速切换到命令行开始处Ctrl + e 切换到命令行末尾Ctrl + r 在历史命令中查找 ctrl + u      删除光标前面所有字符相当于VIM里d shift+^ ct ...

  7. 关于其它模块的设计,有非常多须要自己去构建和完毕,在这里就简单地举几个样例来看看其它模块的设计。我们要做的就是有更改password模块,客户选择模块和关于本软件模块。更改password模块用来更改管理员的password,客户选择对话框模块用来选择已加入的客户,关于本软件模块用来说明客户管理系统的一些必要信息和制作人的信息。

            五,其它模块设计         关于其它模块的设计,有非常多须要自己去构建和完毕,在这里就简单地举几个样例来看看其它模块的设计. 我们要做的就是有更改password模块.客户选择模 ...

  8. linux生成指定大小的文件(转)

    # dd if=/dev/zero of=50M.file bs=1M count=50在当前目录下生成一个50M的文件 虚拟块设备文件更通用的名称是硬盘镜像文件(Hard Disk Image),但 ...

  9. GLSL经典新手教程汇总

    权威官方文档:https://www.opengl.org/documentation/glsl/ 权威民间金典新手教程:http://blog.csdn.net/racehorse 一个具体完整的G ...

  10. Hadoop datanode无法启动

    原因是多次 hadoop namenode -format  导致 datanode 的version 里的Cluster-Id 不一致 这个Cluster-Id的位置在:  自己设置的数据临时文件/ ...