应用EF 6代码优先的迁移-找不到上下文类型

问题描述

我正在研究WCF .NET Framework 4.8项目,它的WCF自托管在控制台应用程序中。

我已经在WCF控制台应用程序引用的单独项目中设置了定义的POCO类和DbContext

我已经在主控制台应用程序内的app.config中为DbContext声明了连接字符串

当我尝试执行EnableMigrationsAdd-Migration之类的EF Code First命令时,它们无法执行,并显示以下错误

No context type was found in the assembly 'MAL.App.ConsoleHost'

Package Manager Console Error

控制台应用程序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的项目定义,因为这是您要在其中管理迁移的项目。

Changing the default project in the package manager console

尽管这里有问题,但仍将默认项目保留在解决方案中作为控制台应用。

  • 解决方案默认项目不仅仅是单击F5即可运行的项目,这是Visual Studio需要访问应用程序/网络配置的任何时间使用的项目文件在运行时。
  • 这与具有EDMX设计图面的EF以前的版本相同,甚至在使用DataSet设计器之前, Default Project 配置文件中的连接字符串也是设计中使用的VS。时间。

您还可以对大多数EF CLI命令使用-ProjectName参数来传递项目名称,而不是使用默认名称。为了简洁起见,我通常将其保留给存在多个具有上下文的项目的场景,尤其是当同一项目中存在多个上下文的场景。您不需要每次都要Add-MigrationUpdate-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