如何解决应用EF 6代码优先的迁移-找不到上下文类型
我正在研究WCF .NET Framework 4.8项目,它的WCF自托管在控制台应用程序中。
我已经在WCF控制台应用程序引用的单独项目中设置了定义的POCO类和DbContext
。
我已经在主控制台应用程序内的app.config中为DbContext
声明了连接字符串。
当我尝试执行EnableMigrations
和Add-Migration
之类的EF Code First命令时,它们无法执行,并显示以下错误:
No context type was found in the assembly 'MAL.App.ConsoleHost'
控制台应用程序App.Config
<entityFramework>
<providers>
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices,EntityFramework.SqlServer"/>
</providers>
</entityFramework>
<connectionStrings>
<add name="AppDbContext" connectionString="Data Source=MySQLEXPRESS;Initial Catalog=MyDB;Integrated Security=True" providerName="System.Data.SqlClient"/>
</connectionStrings>
数据类库
public class AppDbContext: DbContext
{
public DbSet<Album> Albums { get; set; }
public DbSet<AlbumType> AlbumTypes { get; set; }
public DbSet<Artist> Artists { get; set; }
}
一个POCO班
public class Album
{
public Guid AlbumID { get; set; }
public string AlbumName { get; set; }
public Guid ArtistID { get; set; }
public Guid AlbumTypeID { get; set; }
public int Stock { get; set; }
public Artist Artist { get; set; }
public AlbumType AlbumType { get; set; }
}
控制台主程序
static void Main(string[] args)
{
ServiceHost hostMusicService = new ServiceHost(typeof(MyWebServices));
hostMusicService.Open();
Console.WriteLine("Web Services Started. Press [Enter] To Exit ");
Console.ReadLine();
hostMusicService.Close();
}
解决方法
当在与主运行时不同的项目中定义了DbContext并将主运行时设置为解决方案中的默认项目时,会发生此错误。
首次打开Package Manager控制台时,它假定解决方案 Default Project 是您要针对其执行命令的项目,例如Enable-Migrations
。
您可以更改解决方案的默认项目,但是更简单的方法是将Package Manager控制台中的默认项目更改或设置为具有AppDbContext
的项目定义,因为这是您要在其中管理迁移的项目。
尽管这里有问题,但仍将默认项目保留在解决方案中作为控制台应用。
- 解决方案默认项目不仅仅是单击F5即可运行的项目,这是Visual Studio需要访问应用程序/网络配置的任何时间使用的项目文件在运行时。
- 这与具有EDMX设计图面的EF以前的版本相同,甚至在使用DataSet设计器之前, Default Project 配置文件中的连接字符串也是设计中使用的VS。时间。
您还可以对大多数EF CLI命令使用-ProjectName
参数来传递项目名称,而不是使用默认名称。为了简洁起见,我通常将其保留给存在多个具有上下文的项目的场景,尤其是当同一项目中存在多个上下文的场景。您不需要每次都要Add-Migration
或Update-DataBase
或其他类似这样的脚手架命令,每次都输入项目名称。
要获取有关支持的参数的信息,请在控制台中的命令后使用-?
开关:
PM> Enable-Migrations -?
NAME
Enable-Migrations
SYNOPSIS
Enables Code First Migrations in a project.
SYNTAX
Enable-Migrations [-ContextTypeName <String>] [-EnableAutomaticMigrations] [-MigrationsDirectory <String>] [-ProjectName <String>] [-StartUpProjectName <String>] [-ContextProjectName <String>] [-ConnectionStringName <String>]
[-Force] [-ContextAssemblyName <String>] [-AppDomainBaseDirectory <String>] [<CommonParameters>]
Enable-Migrations [-ContextTypeName <String>] [-EnableAutomaticMigrations] [-MigrationsDirectory <String>] [-ProjectName <String>] [-StartUpProjectName <String>] [-ContextProjectName <String>] -ConnectionString <String>
-ConnectionProviderName <String> [-Force] [-ContextAssemblyName <String>] [-AppDomainBaseDirectory <String>] [<CommonParameters>]
DESCRIPTION
Enables Migrations by scaffolding a migrations configuration class in the project. If the
target database was created by an initializer,an initial migration will be created (unless
automatic migrations are enabled via the EnableAutomaticMigrations parameter).
RELATED LINKS
REMARKS
To see the examples,type: "get-help Enable-Migrations -examples".
For more information,type: "get-help Enable-Migrations -detailed".
For technical information,type: "get-help Enable-Migrations -full".
PM>
,
我找到了答案。您需要在“迁移”中添加数据类库项目名称,如下所示;
- Enable-Migrations -ProjectName MyContextProjectNameHere -StartUpProjectName MyStartUpProjectNameHere -Verbose
- add-migration Initial -ProjectName MyContextProjectNameHere
- update-database -ProjectName MyContextProjectNameHere
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。