我在脚手架和从具有多个DBContext的类库中进行迁移时遇到问题。我找到了一个用于迁移的命令行参数:
dnx ef migration add -c Contexts.IndustryContext initial
但这甚至不能通过命令行解析器获得。我希望所有的DBContexts和数据库内容都出自MVC 6主Web项目并位于其自己的DLL中。这可能吗?需要什么命令行魔术?
我一直在寻找这个问题的答案,并想为ef core 2.0提供我的解决方案。
Microsoft.EntityFrameworkCore.Tools.DotNet
需要添加到其中每个都有的类库DbContext
中。右键单击该项目,然后选择Edit *.csproj
。然后,添加以下内容:
注意:该版本是本文发布时的最新版本,将来可能会更改。
接下来,我创建了一个名为Migrations.Console的新控制台应用程序(.NET Core),并将其添加到了我的解决方案中。您将必须DbContext
在此项目中引用所有类库。
我安装Microsoft.EntityFrameworkCore
和Microsoft.EntityFrameworkCore.Design
的NuGet包。
在Migrations.Console
应用程序中,我为我拥有的每个Db上下文创建了一个DbContextFactory类。
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Design; public class ApplicationDbContextFactory : IDesignTimeDbContextFactory{ public ApplicationDbContext CreateDbContext(string[] args) { var builder = new DbContextOptionsBuilder (); builder.UseSqlServer("Server=(local);Database=DATABASENAME;Trusted_Connection=True;MultipleActiveResultSets=true"); return new ApplicationDbContext(builder.Options); } }
注意:确保更新上下文和连接字符串以匹配您的项目。
现在DbContextFactory
已经创建了每个迁移,您可以开始创建迁移。转到您的课程库的文件夹。右键单击项目和的最简单方法Open Folder in File Explorer
。然后,键入cmd
的地址栏File Explorer
以在该文件夹中打开命令提示符。
现在,使用以下命令创建迁移:
dotnet ef migrations add InitialCreate -c ApplicationDbContext --startup-project ../Migrations.Console/Migrations.Console.csproj
注意:进行更改ApplicationDbContext
以匹配您正在使用的上下文的名称。另外,如果您使用其他名称调用控制台项目,则需要更改路径和名称。
现在,您应该Migrations
在类库中看到一个文件夹。