MVC Framework - Modelle
Die Komponente 'Modell' ist für die Verwaltung der Daten der Anwendung verantwortlich. Es reagiert auf die Anforderung aus der Ansicht und auf Anweisungen des Controllers, sich selbst zu aktualisieren.
Modellklassen können entweder manuell erstellt oder aus Datenbankentitäten generiert werden. In den kommenden Kapiteln werden wir viele Beispiele für das manuelle Erstellen von Modellen sehen. Daher werden wir in diesem Kapitel die andere Option ausprobieren, dh aus der Datenbank generieren, damit Sie praktische Erfahrung mit beiden Methoden haben.
Erstellen Sie Datenbankentitäten
Stellen Sie eine Verbindung zu SQL Server her und erstellen Sie eine neue Datenbank.
Führen Sie nun die folgenden Abfragen aus, um neue Tabellen zu erstellen.
CREATE TABLE [dbo].[Student](
[StudentID] INT IDENTITY (1,1) NOT NULL,
[LastName] NVARCHAR (50) NULL,
[FirstName] NVARCHAR (50) NULL,
[EnrollmentDate] DATETIME NULL,
PRIMARY KEY CLUSTERED ([StudentID] ASC)
)
CREATE TABLE [dbo].[Course](
[CourseID] INT IDENTITY (1,1) NOT NULL,
[Title] NVARCHAR (50) NULL,
[Credits] INT NULL,
PRIMARY KEY CLUSTERED ([CourseID] ASC)
)
CREATE TABLE [dbo].[Enrollment](
[EnrollmentID] INT IDENTITY (1,1) NOT NULL,
[Grade] DECIMAL(3,2) NULL,
[CourseID] INT NOT NULL,
[StudentID] INT NOT NULL,
PRIMARY KEY CLUSTERED ([EnrollmentID] ASC),
CONSTRAINT [FK_dbo.Enrollment_dbo.Course_CourseID] FOREIGN KEY ([CourseID])
REFERENCES [dbo].[Course]([CourseID]) ON DELETE CASCADE,
CONSTRAINT [FK_dbo.Enrollment_dbo.Student_StudentID] FOREIGN KEY ([StudentID])
REFERENCES [dbo].[Student]([StudentID]) ON DELETE CASCADE
)
Generieren Sie Modelle mithilfe von Datenbankentitäten
Nachdem Sie die Datenbank erstellt und die Tabellen eingerichtet haben, können Sie eine neue leere MVC-Anwendung erstellen. Klicken Sie mit der rechten Maustaste auf den Ordner Modelle in Ihrem Projekt und wählen Sie Hinzufügen → Neues Element. Wählen Sie dann ADO.NET-Entitätsdatenmodell aus.
Wählen Sie im nächsten Assistenten "Aus Datenbank generieren" und klicken Sie auf "Weiter". Stellen Sie die Verbindung zu Ihrer SQL-Datenbank ein.
Wählen Sie Ihre Datenbank aus und klicken Sie auf Verbindung testen. Ein Bildschirm ähnlich dem folgenden folgt. Weiter klicken.
Wählen Sie Tabellen, Ansichten und gespeicherte Prozeduren und Funktionen aus. Klicken Sie auf Fertig stellen. Sie sehen die Modellansicht wie im folgenden Screenshot gezeigt erstellt.
Die obigen Vorgänge würden automatisch eine Modelldatei für alle Datenbankentitäten erstellen. Die von uns erstellte Student-Tabelle führt beispielsweise zu einer Modelldatei Student.cs mit dem folgenden Code:
namespace MvcModelExample.Models {
using System;
using System.Collections.Generic;
public partial class Student {
public Student() {
this.Enrollments = new HashSet();
}
public int StudentID { get; set; }
public string LastName { get; set; }
public string FirstName { get; set; }
public Nullable EnrollmentDate { get; set; }
public virtual ICollection Enrollments { get; set; }
}
}