欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-05 20:53:31
原文地址:http://www.entityframeworktutorial.net/code-first/database-initialization-in-code-first.aspx 在本系列教程的Code-First示例一节中,我们已经看到了EF 自动创建数据库的过程。这一节中,我们将 ......

原文地址:

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

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

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

 

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

  1. no parameter【没有参数】
  2. database name【数据库名称】
  3. connection string name 【连接字符串名称】

先看下没有参数的情况吧:

如果你在上下文类中,没有指定任何参数的话,就会在你本地的 sqlexpress 服务器上创建数据库,数据库名称是:{namespace}.{context clas name}.【命名空间.上下文类的名称】,例如下面的代码,ef将会创建schooldatalayer.context名称的数据库。

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

接着看看 第二种情况:数据库名称

你可以在上下文类调用的base构造函数中,传入数据库名称参数,然后ef就会创建你指定的数据库名称的数据库。例如下面代码,ef为我们创建的是myschooldb数据库。

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

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

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

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

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

在上面的上下文类中,我们指定了一个连接字符串作为参数。请注意的是,连接字符串应该是【name=】开头,否则就被被认为是数据库的名称,上面配置文件中数据库是schooldb-byconnectionstring。ef就会为我们创建这个名称的数据库。请注意,你需要确保

providername = "system.data.sqlclient" 包含在连接字符串中。

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