EntityFramework 啓用遷移 Enable-Migrations 報異常 "No context type was found in the assembly"

以前做項目的時候,沒有采用分類庫的形式,所以遷移一致非常順利,沒有出現過任何狀況。

這次做項目稍微有點大,必須要分類庫才方便開發維護。

在解決方案中啓用項目EntityFramework遷移時卻發生了異常。

異常說在我的項目中沒有找到DBContext類。

這個DBContext類確實沒有放在啓動項目下面,是另外建立了一個獨立的類庫來存放。

在啓動項目中引用了卻無法找到。。。

查看get-help Enable-Migrations幫助,發現啓用遷移命令帶了幾個參數。

Enable-Migrations [-ContextTypeName <String>] [-EnableAutomaticMigrations] [-ProjectName <String>] [-StartUpProjectName <String>] [-ConnectionStringName <String>] [-Force] [<CommonParameters>]

ContextTypeName:項目繼承自DBContext的類名字。

EnableAutomaticMigrations:開啓自動遷移。

ProjectName:存放DBContext類的項目名稱。

StartUpProjectName:解決方案中啓動項目的名稱,作用是調用該項目下的連接字符串。

ConnectionStringName:連接字符串名稱

上面五個參數是解決問題必須的,其它的無關緊要。

例如:

Enable-Migrations -ContextTypeName "DBAccessLib.TJSSDBContext" -ProjectName "DBAccessLib" -StartUpProjectName "WebSite" -ConnectionStringName "TJSSDBContext" -Verbose

依次填好之後,問題解決。

同樣的在Add-Migration、Update-Database的時候也需要填寫相應的參數。否則會出現同樣錯誤。

例如:

Add-Migration -Name "EditCST_DevicePhoto"  -ProjectName "DBAccessLib" -StartUpProjectName "WebSite" -ConnectionStringName "TJSSDBContext" -Verbose

Update-Database -Script -ProjectName "DBAccessLib" -StartUpProjectName "WebSite" -ConnectionStringName "TJSSDBContext"  -Verbose

使用過程中注意去掉 script參數

___________________________________________________________________________________________________

ABP項目中

update-database -ProjectName "IB1000Project.EntityFramework" -StartUpProjectName "IB1000Project.Web" -ConnectionStringName "default"  -Verbose
Using StartUp project 'IB1000Project.Web'.
Specify the '-Verbose' flag to view the SQL statements being applied to the target database.
Target database is: 'ib1000Project' (DataSource: 192.168.1.145, Provider: System.Data.SqlClient, Origin: Explicit).
No pending explicit migrations.
Running Seed method.

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

update-database  -ProjectName "IB1000Project.EntityFramework" -StartUpProjectName "IB1000Project.Web" -ConnectionStringName "default"  -Verbose

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章