5.翻译系列:EF 6中数据库的初始化(EF 6 Code-First 系列)
原文地址:
在本系列教程的code-first示例一节中,我们已经看到了ef 自动创建数据库的过程。这一节中,我们将学习code-first模式中,初始化数据库的时候, ef是如何决定创建的数据库名称,以及在哪个服务器上创建数据库。
下面的图形,列出来了数据库初始化的流程,从图中可以看出,流程走向是基于我们传递给上下文类【继承自dbcontext类】的参数的。
就像上图所示,基于上下文的参数,我们有下面几种:
- no parameter【没有参数】
- database name【数据库名称】
- connection string name 【连接字符串名称】
先看下没有参数的情况吧:
如果你在上下文类中,没有指定任何参数的话,就会在你本地的 sqlexpress 服务器上创建数据库,数据库名称是:{namespace}.{context clas name}.【命名空间.上下文类的名称】,例如下面的代码,ef将会创建schooldatalayer.context名称的数据库。
接着看看 第二种情况:数据库名称
你可以在上下文类调用的base构造函数中,传入数据库名称参数,然后ef就会创建你指定的数据库名称的数据库。例如下面代码,ef为我们创建的是myschooldb数据库。
最后看看第三种情况:数据库连接字符串的名称吧。
你可以在app.config配置文件中,配置数据库连接字符串,然后把配置文件中连接字符串的名称,传递到上下文类的base构造函数中。形式如下:“name=你的连接字符串名称”。下面的代码,我们传递的是:
在上面的上下文类中,我们指定了一个连接字符串作为参数。请注意的是,连接字符串应该是【name=】开头,否则就被被认为是数据库的名称,上面配置文件中数据库是schooldb-byconnectionstring。ef就会为我们创建这个名称的数据库。请注意,你需要确保
providername = "system.data.sqlclient" 包含在连接字符串中。
好了,这一节就介绍完了,下面一节,将介绍数据库初始化策略。
上一篇: mysql快速导入导出数据
下一篇: Mongodb基本命令总结
推荐阅读
-
5.翻译系列:EF 6中数据库的初始化(EF 6 Code-First 系列)
-
9.3 翻译系列:数据注解特性之Key【EF 6 Code-First 系列】
-
2.翻译系列:为EF Code-First设置开发环境(EF 6 Code-First系列)
-
6.翻译:EF基础系列---什么是EF中的实体?
-
11.翻译系列:在EF 6中配置一对零或者一对一的关系【EF 6 Code-First系列】
-
9.7 翻译系列:EF数据注解特性之--InverseProperty【EF 6 Code-First系列】
-
9.翻译系列:EF 6以及EF Core中的数据注解特性(EF 6 Code-First系列)
-
9.9 翻译系列:数据注解特性之--MaxLength 【EF 6 Code-First系列】
-
9.10 翻译系列:EF数据注解特性之StringLength【EF 6 Code-First系列】
-
21.翻译系列:Entity Framework 6 Power Tools【EF 6 Code-First系列】