5.翻译系列:EF 6中数据库的初始化(EF 6 Code-First 系列)

原文地址:http://www.entityframeworktutorial.net/code-first/database-initialization-in-code-first.aspxhtml

 

EF 6 Code-First系列文章目录:数据库

 

 

在本系列教程的Code-First示例一节中,咱们已经看到了EF 自动建立数据库的过程。这一节中,咱们将学习Code-First模式中,初始化数据库的时候, EF是如何决定建立的数据库名称,以及在哪一个服务器上建立数据库。服务器

下面的图形,列出来了数据库初始化的流程,从图中能够看出,流程走向是基于咱们传递给上下文类【继承自DbContext类】的参数的。app

 

就像上图所示,基于上下文的参数,咱们有下面几种:ide

  1. No Parameter【没有参数】
  2. Database Name【数据库名称】
  3. Connection String Name 【链接字符串名称】

先看下没有参数的状况吧:函数

若是你在上下文类中,没有指定任何参数的话,就会在你本地的 SQLEXPRESS 服务器上建立数据库,数据库名称是:{Namespace}.{Context clas Name}.【命名空间.上下文类的名称】,例以下面的代码,EF将会建立SchoolDataLayer.Context名称的数据库。学习

接着看看 第二种状况:数据库名称测试

你能够在上下文类调用的base构造函数中,传入数据库名称参数,而后EF就会建立你指定的数据库名称的数据库。例以下面代码,EF为咱们建立的是MySchoolDB数据库。ui

最后看看第三种状况:数据库链接字符串的名称吧。spa

你能够在app.config配置文件中,配置数据库链接字符串,而后把配置文件中链接字符串的名称,传递到上下文类的base构造函数中。形式以下:“name=你的链接字符串名称”。下面的代码,咱们传递的是:

在上面的上下文类中,咱们指定了一个链接字符串做为参数。请注意的是,链接字符串应该是【name=】开头,不然就被被认为是数据库的名称,上面配置文件中数据库是SchoolDB-ByConnectionString。EF就会为咱们建立这个名称的数据库。请注意,你须要确保

providerName = "System.Data.SqlClient" 包含在链接字符串中。

好了,这一节就介绍完了,下面一节,将介绍数据库初始化策略。

相关文章
相关标签/搜索