首頁 > 軟體

使用EF Code First搭建簡易ASP.NET MVC網站並允許資料庫遷移

2022-09-12 18:00:53

本篇使用EF Code First搭建一個簡易ASP.NET MVC 4網站,並允許資料庫遷移。

建立一個ASP.NET MVC 4 網站。

在Models資料夾內建立Person類。

    public class Person
    {
        public int ID { get; set; }
        public string FirstName { get; set; }
        public string LastName { get; set; }
    }

在Controls資料夾內建立PersonController,選擇使用Entity Framework的模版、模型類,建立資料上下文類,如下:

點選"新增"後,除了在Controls資料夾內多了PersonController,在Models資料夾中多了PersonContext類,如下:

using System.Data.Entity;
namespace MvcApplication1.Models
{
    public class PersonContext : DbContext
    {
        // 您可以向此檔案中新增自定義程式碼。更改不會被覆蓋。
        // 
        // 如果您希望只要更改模型架構,Entity Framework
        // 就會自動刪除並重新生成資料庫,則將以下
        // 程式碼新增到 Global.asax 檔案中的 Application_Start 方法。
        // 注意: 這將在每次更改模型時銷燬並重新建立資料庫。
        // 
        // System.Data.Entity.Database.SetInitializer(new System.Data.Entity.DropCreateDatabaseIfModelChanges<MvcApplication1.Models.PersonContext>());
        public PersonContext() : base("name=PersonContext")
        {
        }
        public DbSet<Person> People { get; set; }
    }
}

在Web.config中的connectionStrings多瞭如下設定,選擇了預設的localdb資料庫。

  <connectionStrings>
    ......
    <add name="PersonContext" connectionString="Data Source=(localdb)v11.0; Initial Catalog=PersonContext-20150210155119; Integrated Security=True; MultipleActiveResultSets=True; AttachDbFilename=|DataDirectory|PersonContext-20150210155119.mdf"
      providerName="System.Data.SqlClient" />
  </connectionStrings>

在Views/資料夾中多了Create.cshtml, Delete.cshtml, Details.cshtml, Edit.cshtml, Index.cshtml這個幾個檢視檔案。

現在,我們想啟動EF的自動遷移功能。點選"工具"-"庫程式包管理器"-"程式包管理器控制檯",輸入enable-migrations:

在根目錄下多了一個Migrations資料夾,以及生成了一個Configuration類,如下:

namespace MvcApplication1.Migrations
{
    using System;
    using System.Data.Entity;
    using System.Data.Entity.Migrations;
    using System.Linq;
    internal sealed class Configuration : DbMigrationsConfiguration<MvcApplication1.Models.PersonContext>
    {
        public Configuration()
        {
            AutomaticMigrationsEnabled = false;
        }
        protected override void Seed(MvcApplication1.Models.PersonContext context)
        {
            //  This method will be called after migrating to the latest version.
            //  You can use the DbSet<T>.AddOrUpdate() helper extension method 
            //  to avoid creating duplicate seed data. E.g.
            //
            //    context.People.AddOrUpdate(
            //      p => p.FullName,
            //      new Person { FullName = "Andrew Peters" },
            //      new Person { FullName = "Brice Lambson" },
            //      new Person { FullName = "Rowan Miller" }
            //    );
            //
        }
    }
}

以上,我們可以新增一些種子資料。

現在需要把種子資料遷移到資料庫,在"程式包管理器控制檯",輸入add-migration initial

此時,在Migrations資料夾內多了201502100756322_initial類,記錄了本次遷移的動作。

namespace MvcApplication1.Migrations
{
    using System;
    using System.Data.Entity.Migrations;
    
    public partial class initial : DbMigration
    {
        public override void Up()
        {
            CreateTable(
                "dbo.People",
                c => new
                    {
                        ID = c.Int(nullable: false, identity: true),
                        FirstName = c.String(),
                        LastName = c.String(),
                    })
                .PrimaryKey(t => t.ID);
            
        }
        
        public override void Down()
        {
            DropTable("dbo.People");
        }
    }
}

最後別忘了要更新資料庫,在"程式包管理器控制檯",輸入update-database:

這時候,瀏覽/Person/Index,能實現所有的增刪改功能。

如果這時候,我們希望在Person中增加一個屬性,比如型別為int的Age屬性。

    public class Person
    {
        public int ID { get; set; }
        public string FirstName { get; set; }
        public string LastName { get; set; }
        public int Age { get; set; }
    }

我們如何告訴資料庫呢?

還是在"程式包管理器控制檯",輸入add-migration 名稱

此時,在Migrations資料夾內多了201502100812315_addedage類,記錄了本次遷移的動作。

最後,還在"程式包管理器控制檯",輸入update-database以更新資料庫。

為了讓檢視與當前Person類同步,可以先後刪除Person資料夾和PersonController控制器,再重新建立PersonController控制器,選擇使用Entity Framework的模版、Person類,PersonContext上下文類。

至此,簡單體驗了EF Code First建立資料庫並實現資料庫遷移的方便之處。

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對it145.com的支援。如果你想了解更多相關內容請檢視下面相關連結


IT145.com E-mail:sddin#qq.com