通过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 搜到确实和我想象的一致都是通过此命令来设置多个数据库上下文的迁移文件路径 在抱着试试看的态度,进行了如下命令输入:
Enable-Migrations -ContextTypeName:JackSite.Entities.Models.StudyTime.JackDbContext -MigrationsDirectory:Migrations\StudyTimeMigrations
ContextTypeName:DbContext的位置,即DbContext的命名空间加上DbContext的名称
MigrationsDirectory:需要迁移到的目标文件夹
PS:注意MigrationsDirectory:Migrations\StudyTimeMigrations
中的'\'不要打错如输成'/'可能会引发一些问题
同样我们对另一个数据上下文进行设置
Enable-Migrations -ContextTypeName:JackSite.Entities.Models.Blog.BlogDbContext -MigrationsDirectory:Migrations\BlogMigrations
PS:这里两个DbContext用的是同样的连接串
更新数据脚本
最后通过运行Add-Migrations
命令
这里需要注意:如果我们只有一个数据上下文,通过
Add-Migrations
命令会自动选择唯一的DbContext,但是如果有多个DbContext,我们必须指定我们需要对那个DbContext进行修改
Add-Migration -ConfigurationTypeName JackSite.Entities.Migrations.BlogMigrations.Configuration InitBlogDb
这里通过-ConfigurationTypeName
指定Configuration 后面接着是Configuration的路径,然后接着是我们取得名字InitBlogDb
EF会找到指定的Configuration,并添加XXXX_InitBlogDb,结构如下图所示:
最后通过Update-Database
进行更新
同样,我们这里需要指定需要更新哪个Configuration
Update-Database JackSite.Entities.Migrations.BlogMigrations.Configuration
参考资料
Entity Framework 6 Code First Migrations with Multiple Data Contexts