位置:首頁 > Web開發 > MVC框架教學 > MVC框架 - 模型

MVC框架 - 模型

模型負責管理應用程序的數據。它響應視圖的請求,同時也響應指令從控製器到自我更新。

模型類可以手動創建或從數據庫實體創建產生。 我們將看到很多手動創建模型的例子在接下來的章節中。因此,在本章中,我們將嘗試另一種選擇,即從數據庫中生成,使有自動和手動兩種方法。

創建數據庫實體

連接到SQL Server,並創建一個新的數據庫。

connect_sql_server

現在,運行以下查詢語句來創建新表:

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
)

使用數據庫實體生成模型

創建數據庫並設置了表之後,你可以繼續前進,創建一個新空的MVC應用程序。 現在,在您的項目右鍵點擊Models文件夾,並選擇Add->New 項並選擇ADO.NET 實體數據模型。

add_new_model_step_1
add_new_model_step_2

在接下來的向導中,選擇生成數據庫,然後單擊下一步。設置連接到SQL數據庫。

add_new_model_test_connection

選擇數據庫並單擊測試連接。與此類似,屏幕將會隨之顯示。點擊下一步。

add_new_model_test_connection_step_2

選擇表,視圖和存儲過程和函數,然後單擊完成。將看到模型視圖創建是這樣的:

new_mvc_model

上述操作將自動創建所有的數據庫實體模型文件。示例,我們創建的學生表將產生一個模型文件Student.cs,如下麵的代碼:

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; }
    }
}