[关闭]
@a604572782 2015-08-10T16:03:24.000000Z 字数 1640 阅读 3205

通过Migration在EF6中用多个DbContext

EF EF6 C# Migration


前言

本人在阿里云申请了个免费的空间,之前已经存放了一个项目,由于之前一直没时间,近期比较有空,所以想开发个个人博客,但是由于阿里云没有给我们权限来新建数据库,因此只能在原有的数据库另外“瓜分”一部分空间来做个人博客的数据库,我是在之前的JackSite.Entities实体项目上开发,因此只需要在定义一个DbContext即可。

PS:本次讨论的使用范围通过EF6(低版本是否支持多数据上下文我并不了解)用一个数据库构造多个DbContext

实现目标

原始项目

原本默认Migration的文件是在Migrations,我现在希望已如下的形式来存放

新项目

Migrations项目中添加文件夹AMigration,BMigration文件来区分不同的DbContext迁移文件。

设置多数据上下文

首先我查找了下资料并未发现有类似Move-Migrations或者Update-Migrations的命令,因此我设想是是否同样是通过Enable-Migrations进行设置
通过google 搜索关键字Single Database Multiple DbContext 搜到确实和我想象的一致都是通过此命令来设置多个数据库上下文的迁移文件路径 在抱着试试看的态度,进行了如下命令输入:

  1. Enable-Migrations -ContextTypeName:JackSite.Entities.Models.StudyTime.JackDbContext -MigrationsDirectory:Migrations\StudyTimeMigrations

ContextTypeNameDbContext的位置,即DbContext的命名空间加上DbContext的名称
MigrationsDirectory:需要迁移到的目标文件夹
PS:注意MigrationsDirectory:Migrations\StudyTimeMigrations中的'\'不要打错如输成'/'可能会引发一些问题
同样我们对另一个数据上下文进行设置

  1. Enable-Migrations -ContextTypeName:JackSite.Entities.Models.Blog.BlogDbContext -MigrationsDirectory:Migrations\BlogMigrations

PS:这里两个DbContext用的是同样的连接串

更新数据脚本

最后通过运行Add-Migrations命令

这里需要注意:如果我们只有一个数据上下文,通过Add-Migrations命令会自动选择唯一的DbContext,但是如果有多个DbContext,我们必须指定我们需要对那个DbContext进行修改

  1. Add-Migration -ConfigurationTypeName JackSite.Entities.Migrations.BlogMigrations.Configuration InitBlogDb

这里通过-ConfigurationTypeName指定Configuration 后面接着是Configuration的路径,然后接着是我们取得名字InitBlogDb
EF会找到指定的Configuration,并添加XXXX_InitBlogDb,结构如下图所示:

结构
最后通过Update-Database进行更新

同样,我们这里需要指定需要更新哪个Configuration

  1. Update-Database JackSite.Entities.Migrations.BlogMigrations.Configuration

更新数据库

参考资料

Entity Framework 6 Code First Migrations with Multiple Data Contexts

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注