W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
Contoso University Web 應(yīng)用演示了如何使用 EF Core 和 Visual Studio 創(chuàng)建 Razor 頁面 Web 應(yīng)用。若要了解系列教程,請(qǐng)參閱第一個(gè)教程。
本教程使用 EF Core 遷移功能管理數(shù)據(jù)模型更改。
如果遇到無法解決的問題,請(qǐng)下載已完成應(yīng)用。
開發(fā)新應(yīng)用時(shí),數(shù)據(jù)模型會(huì)頻繁更改。 每當(dāng)模型發(fā)生更改時(shí),都無法與數(shù)據(jù)庫進(jìn)行同步。 本教程首先配置 Entity Framework 以創(chuàng)建數(shù)據(jù)庫(如果不存在)。 每當(dāng)數(shù)據(jù)模型發(fā)生更改時(shí):
這種使 DB 與數(shù)據(jù)模型保持同步的方法適用于多種情況,但將應(yīng)用部署到生產(chǎn)環(huán)境的情況除外。 當(dāng)應(yīng)用在生產(chǎn)環(huán)境中運(yùn)行時(shí),應(yīng)用通常會(huì)存儲(chǔ)需要保留的數(shù)據(jù)。 每當(dāng)發(fā)生更改(例如添加新列)時(shí),應(yīng)用都無法在具有測(cè)試 DB 的環(huán)境下啟動(dòng)。 EF Core 遷移功能可通過使 EF Core 更新 DB 架構(gòu)而不是創(chuàng)建新 DB 來解決此問題。
數(shù)據(jù)模型發(fā)生更改時(shí),遷移將更新架構(gòu)并保留現(xiàn)有數(shù)據(jù),而無需刪除或重新創(chuàng)建 DB。
使用 SQL Server 對(duì)象資源管理器 (SSOX) 或 database drop 命令:
在“包管理器控制臺(tái)”(PMC) 中運(yùn)行以下命令:
Drop-Database
從 PMC 運(yùn)行 Get-Help about_EntityFrameworkCore
,獲取幫助信息。
生成項(xiàng)目并創(chuàng)建第一個(gè)遷移。
Add-Migration InitialCreate
Update-Database
EF Core migrations add 命令已生成用于創(chuàng)建 DB 的代碼。 此遷移代碼位于 Migrations<timestamp>_InitialCreate.cs 文件中。 InitialCreate 類的 Up 的方法創(chuàng)建與數(shù)據(jù)模型實(shí)體集相對(duì)應(yīng)的 DB 表。 Down 方法刪除這些表,如下例所示:
C#
public partial class InitialCreate : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.CreateTable(
name: "Course",
columns: table => new
{
CourseID = table.Column<int>(nullable: false),
Title = table.Column<string>(nullable: true),
Credits = table.Column<int>(nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_Course", x => x.CourseID);
});
migrationBuilder.CreateTable(
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropTable(
name: "Enrollment");
migrationBuilder.DropTable(
name: "Course");
migrationBuilder.DropTable(
name: "Student");
}
}
遷移調(diào)用 Up 方法為遷移實(shí)現(xiàn)數(shù)據(jù)模型更改。 輸入用于回退更新的命令時(shí),遷移調(diào)用 Down 方法。
前面的代碼適用于初始遷移。 該代碼是運(yùn)行 migrations add InitialCreate 命令時(shí)創(chuàng)建的。 遷移名稱參數(shù)(本示例中為“InitialCreate”)用于指定文件名。 遷移名稱可以是任何有效的文件名。 最好選擇能概括遷移中所執(zhí)行操作的字詞或短語。 例如,添加了系表的遷移可稱為“AddDepartmentTable”。
如果創(chuàng)建了初始遷移并且存在 DB:
如果將應(yīng)用部署到新環(huán)境,則必須運(yùn)行 DB 創(chuàng)建代碼才能創(chuàng)建 DB。
先前刪除了 DB,因此已不存在,所以遷移會(huì)創(chuàng)建新的 DB。
遷移在 Migrations/SchoolContextModelSnapshot.cs 中創(chuàng)建當(dāng)前數(shù)據(jù)庫架構(gòu)的快照。 添加遷移時(shí),EF 會(huì)通過將數(shù)據(jù)模型與快照文件進(jìn)行對(duì)比來確定已更改的內(nèi)容。
若要?jiǎng)h除遷移,請(qǐng)使用以下命令:
Remove-Migration
刪除遷移命令會(huì)刪除遷移并確保正確重置快照。
早期開發(fā)使用了 EnsureCreated。 本教程將使用遷移。 EnsureCreated 具有以下限制:
刪除 EnsureCreated:
C#
context.Database.EnsureCreated();
運(yùn)行應(yīng)用并驗(yàn)證 DB 設(shè)定為種子。
使用 SQL Server 對(duì)象資源管理器檢查 DB。 請(qǐng)注意,增加了 __EFMigrationsHistory 表。 __EFMigrationsHistory 表跟蹤已應(yīng)用到 DB 的遷移。 查看 __EFMigrationsHistory 表中的數(shù)據(jù),其中顯示對(duì)應(yīng)初始遷移的一行數(shù)據(jù)。 上面的 CLI 輸出示例中最后部分的日志顯示了創(chuàng)建此行的 INSERT 語句。
運(yùn)行應(yīng)用并驗(yàn)證一切正常運(yùn)行。
不建議生產(chǎn)應(yīng)用在應(yīng)用程序啟動(dòng)時(shí)調(diào)用 Database.Migrate。 不應(yīng)從服務(wù)器場(chǎng)中的應(yīng)用調(diào)用 Migrate。 例如,已將應(yīng)用在云中部署為橫向擴(kuò)展(運(yùn)行應(yīng)用的多個(gè)示例)的情況。
應(yīng)在部署過程中以受控的方式執(zhí)行數(shù)據(jù)庫遷移。 生產(chǎn)數(shù)據(jù)庫遷移方法包括:
EF Core 使用 __MigrationsHistory 表查看是否需要運(yùn)行任何遷移。 如果 DB 已是最新,則無需運(yùn)行遷移。
下載已完成應(yīng)用。
應(yīng)用會(huì)生成以下異常:
text
SqlException: Cannot open database "ContosoUniversity" requested by the login.
The login failed.
Login failed for user 'user name'.
解決方案:運(yùn)行 dotnet ef database update
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: