Tutorial: Teil 5, Anwenden von Migrationen auf das Contoso University-Beispiel

In diesem Tutorial verwenden Sie zunächst das EF Core-Migrationsfeature zum Verwalten von Datenmodelländerungen. In späteren Tutorials fügen Sie weitere Migrationen hinzu, wenn Sie das Datenmodell ändern.

In diesem Tutorial:

  • Erfahren Sie mehr über Migrationen
  • Erstellen einer ursprünglichen Migration
  • Untersuchen Sie Up- und Down-Methoden
  • Erfahren Sie mehr über die Datenmodell-Momentaufnahme
  • Anwenden der Migration

Voraussetzungen

Informationen zu Migrationen

Wenn Sie eine neue Anwendung entwickeln, ändert sich Ihr Datenmodell häufig. Jedes Mal, wenn das Datenmodell geändert wird, ist es nicht mehr synchron mit der Datenbank. Sie haben zu Beginn dieser Tutorials Entity Framework für die Erstellung der Datenbank konfiguriert, sofern diese nicht vorhanden war. Anschließend können Sie bei jeder Datenmodelländerung (beim Hinzufügen, Entfernen oder Ändern von Entitätsklassen oder beim Ändern Ihrer DbContext-Klasse) die Datenbank löschen. EF erstellt dann eine neue Datenbank, die dem Modell entspricht, und startet diese mit Testdaten.

Diese Methode, bei der die Datenbank mit dem Datenmodell synchron gehalten wird, funktioniert so lange, bis Sie die Anwendung für die Produktion bereitstellen. Wenn sich die Anwendung in der Produktion befindet, speichert sie in der Regel die Daten, die Sie weiter verwenden möchten, da nicht bei jeder Änderung, wie z.B. dem Hinzufügen einer neuen Spalte, alle Daten verloren gehen sollen. Mit dem EF Core-Migrationsfeature wird dieses Problem gelöst, indem EF das Datenbankschema aktualisiert, statt eine neue Datenbank zu erstellen.

Für die Arbeit mit Migrationen können Sie die Paket-Manager-Konsole (Package Manager Console, PMC) oder die CLI verwenden. In diesen Tutorials wird die Verwendungsweise von CLI-Befehlen erläutert. Informationen zur PMC finden Sie am Ende dieses Tutorials.

Löschen der Datenbank

Installieren Sie EF Core-Tools als globales Tool, und löschen Sie die Datenbank:

dotnet tool install --global dotnet-ef
dotnet ef database drop

Hinweis

Standardmäßig stellt die Architektur der zu installierenden .NET-Binärdateien die derzeit ausgeführte Betriebssystemarchitektur dar. Informationen zum Angeben einer anderen Betriebssystemarchitektur finden Sie unter dotnet tool install, --arch option. Weitere Informationen finden Sie unter dem GitHub-Issue dotnet/docs #29262.

Im folgenden Abschnitt wird erläutert, wie CLI-Befehle ausgeführt werden.

Erstellen einer ursprünglichen Migration

Speichern Sie Ihre Änderungen, und erstellen Sie das Projekt. Öffnen Sie anschließend ein Befehlsfenster, und navigieren Sie zu dem Projektordner. Sie können diesen Vorgang auf folgende Weise beschleunigen:

  • Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf das Projekt, und wählen Sie aus dem Kontextmenü die Option Ordner in Datei-Explorer öffnen aus.

    Menüelement „In Datei-Explorer öffnen“

  • Geben Sie in die Adressleiste „cmd“ ein, und drücken Sie die EINGABETASTE.

    Öffnen des Befehlsfensters

Geben Sie im Befehlsfenster folgenden Befehl ein:

dotnet ef migrations add InitialCreate

Mit den obigen Befehlen wird eine ähnliche Ausgabe wie die folgende angezeigt:

info: Microsoft.EntityFrameworkCore.Infrastructure[10403]
      Entity Framework Core initialized 'SchoolContext' using provider 'Microsoft.EntityFrameworkCore.SqlServer' with options: None
Done. To undo this action, use 'ef migrations remove'

Wenn Sie die Fehlermeldung „cannot access the file ... ContosoUniversity.dll because it is being used by another process.“ („kann nicht auf die Datei … ContosoUniversity.dll zugreifen, weil sie von einem anderen Vorgang verwendet wird“) sehen, suchen Sie das IIS Express-Symbol in der Windows-Taskleiste, führen Sie einen Rechtsklick aus, und klicken Sie dann auf ContosoUniversity > Stop Site (Site beenden).

Untersuchen Sie Up- und Down-Methoden

Wenn Sie den Befehl migrations add ausgeführt haben, hat EF den Code generiert, mit dem die Datenbank von Grund auf neu erstellt wird. Dieser Code befindet sich im Ordner Migrations in der Datei <timestamp>_InitialCreate.cs. Mit der Methode Up der InitialCreate-Klasse werden die Datenbanktabellen erstellt, die den Datenmodellentitäten entsprechen, und mit der Methode Down werden die Datenbanktabellen gelöscht (siehe folgendes Beispiel).

public partial class InitialCreate : Migration
{
    protected override void Up(MigrationBuilder migrationBuilder)
    {
        migrationBuilder.CreateTable(
            name: "Course",
            columns: table => new
            {
                CourseID = table.Column<int>(nullable: false),
                Credits = table.Column<int>(nullable: false),
                Title = table.Column<string>(nullable: true)
            },
            constraints: table =>
            {
                table.PrimaryKey("PK_Course", x => x.CourseID);
            });

        // Additional code not shown
    }

    protected override void Down(MigrationBuilder migrationBuilder)
    {
        migrationBuilder.DropTable(
            name: "Enrollment");
        // Additional code not shown
    }
}

Die Migrationsfunktion ruft die Methode Up auf, um die Datenmodelländerungen für eine Migration zu implementieren. Wenn Sie einen Befehl eingeben, um ein Rollback für das Update auszuführen, ruft die Migrationsfunktion die Methode Down auf.

Dieser Code ist für die ursprüngliche Migration vorgesehen, die bei der Eingabe des Befehls migrations add InitialCreate erstellt wurde. Der Parameter für den Migrationsnamen (in dem Beispiel „InitialCreate“) wird für den Dateinamen verwendet und kann einen beliebigen Namen haben. Es wird empfohlen, ein Wort oder einen Ausdruck auszuwählen, durch das bzw. den der Hintergrund der Migration widergespiegelt wird. Sie können einer späteren Migration beispielsweise den Namen „AddDepartmentTable“ geben.

Wenn Sie die ursprüngliche Migration erstellt haben, als die Datenbank bereits vorhanden war, wird der Code für die Datenbankerstellung zwar generiert, allerdings muss er nicht ausgeführt werden, da die Datenbank bereits dem Datenmodell entspricht. Wenn Sie die App in einer anderen Umgebung bereitstellen, in der die Datenbank noch nicht vorhanden ist, wird dieser Code ausgeführt, um Ihre Datenbank zu erstellen. Daher sollte dieser zunächst getestet werden. Aus diesem Grund haben Sie die Datenbank vorhin gelöscht: damit die Migrationen eine neue Datenbank von Grund auf erstellen können.

Die Momentaufnahme des Datenmodells

Die Migrationsfunktion erstellt unter Migrations/SchoolContextModelSnapshot.cs eine Momentaufnahme des aktuellen Datenbankschemas. Wenn Sie eine Migration hinzufügen, bestimmt EF die vorgenommenen Änderungen, indem das Datenmodell mit der Momentaufnahmedatei verglichen wird.

Verwenden Sie den Befehl dotnet ef migrations remove, um eine Migration zu entfernen. dotnet ef migrations remove löscht die Migration und stellt sicher, dass die Momentaufnahme ordnungsgemäß zurückgesetzt wird. Wenn dotnet ef migrations remove fehlschlägt, verwenden Sie dotnet ef migrations remove -v, um weitere Informationen zu diesem Fehler zu erhalten.

Weitere Informationen dazu, wie die Momentaufnahmedatei verwendet wird, finden Sie unter EF Core-Migrationen in Teamumgebungen.

Anwenden der Migration

Geben Sie folgenden Befehl in das Befehlsfenster ein, um die Datenbank mit den darin enthaltenen Tabellen zu erstellen.

dotnet ef database update

Die Ausgabe des Befehls ähnelt der des Befehls migrations add. Der Unterschied besteht darin, dass Ihnen Protokolle für die SQL-Befehle angezeigt werden, mit denen die Datenbank eingerichtet wird. In der folgenden Beispielausgabe werden die meisten Protokolle ausgelassen. Wenn diese Detailebene in Protokollnachrichten nicht angezeigt werden soll, können Sie die Protokollebene in der Datei appsettings.Development.json ändern. Weitere Informationen finden Sie unter Protokollieren in .NET Core und ASP.NET Core.

info: Microsoft.EntityFrameworkCore.Infrastructure[10403]
      Entity Framework Core initialized 'SchoolContext' using provider 'Microsoft.EntityFrameworkCore.SqlServer' with options: None
info: Microsoft.EntityFrameworkCore.Database.Command[20101]
      Executed DbCommand (274ms) [Parameters=[], CommandType='Text', CommandTimeout='60']
      CREATE DATABASE [ContosoUniversity2];
info: Microsoft.EntityFrameworkCore.Database.Command[20101]
      Executed DbCommand (60ms) [Parameters=[], CommandType='Text', CommandTimeout='60']
      IF SERVERPROPERTY('EngineEdition') <> 5
      BEGIN
          ALTER DATABASE [ContosoUniversity2] SET READ_COMMITTED_SNAPSHOT ON;
      END;
info: Microsoft.EntityFrameworkCore.Database.Command[20101]
      Executed DbCommand (15ms) [Parameters=[], CommandType='Text', CommandTimeout='30']
      CREATE TABLE [__EFMigrationsHistory] (
          [MigrationId] nvarchar(150) NOT NULL,
          [ProductVersion] nvarchar(32) NOT NULL,
          CONSTRAINT [PK___EFMigrationsHistory] PRIMARY KEY ([MigrationId])
      );

<logs omitted for brevity>

info: Microsoft.EntityFrameworkCore.Database.Command[20101]
      Executed DbCommand (3ms) [Parameters=[], CommandType='Text', CommandTimeout='30']
      INSERT INTO [__EFMigrationsHistory] ([MigrationId], [ProductVersion])
      VALUES (N'20190327172701_InitialCreate', N'5.0-rtm');
Done.

Verwenden Sie den SQL Server-Objekt-Explorer, um die Datenbank wie im ersten Tutorial zu untersuchen. Sie werden feststellen, dass die Tabelle „__EFMigrationsHistory“ hinzugefügt wurde, in der nachverfolgt wird, welche Migrationen auf die Datenbank angewendet worden sind. Wenn Sie die Daten in dieser Tabelle anzeigen, ist eine Zeile für die erste Migration zu sehen. (Im letzten Protokoll im vorgehenden Beispiel der CLI-Ausgabe wird die INSERT-Anweisung angezeigt, mit der diese Zeile erstellt wird.)

Führen Sie die Anwendung aus, um zu überprüfen, ob alles wie gewohnt funktioniert.

Indexseite „Studenten“

Vergleich von CLI und PMC

Die EF-Tools für die Verwaltung von Migrationen sind über .NET CLI-Befehle oder über PowerShell-Cmdlets im Visual Studio-Fenster Paket-Manager-Console (PMC) verfügbar. In diesem Tutorial wird die Verwendungsweise der CLI erläutert. Sie können aber auch die PMC verwenden, wenn Sie diese bevorzugen.

Die EF-Befehle für die PMC-Befehle sind im Paket Microsoft.EntityFrameworkCore.Tools enthalten. Dieses Paket ist im Microsoft.AspNetCore.App-Metapaket enthalten, weshalb Sie keinen Paketverweis hinzufügen müssen, wenn Ihre App über einen Paketverweis für Microsoft.AspNetCore.App verfügt.

Wichtig: Dieses Paket ist nicht mit dem Paket identisch, das Sie für die CLI durch Bearbeitung der .csproj-Datei installiert haben. Der Name dieses Pakets endet mit Tools, im Gegensatz zum Namen des CLI-Pakets, der mit Tools.DotNet endet.

Weitere Informationen zu CLI-Befehlen finden Sie unter .NET CLI.

Weitere Informationen zu den PMC-Befehlen finden Sie unter Paket-Manager-Konsole (Visual Studio).

Abrufen des Codes

Download or view the completed app (Herunterladen oder anzeigen der vollständigen App).

Nächster Schritt

Fahren Sie mit dem nächsten Tutorial fort, um fortgeschrittenere Themen zum Erweitern des Datenmodells kennenzulernen. Dabei werden Sie weitere Migrationen erstellen und anwenden.