亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

使用EF Code First搭建簡(jiǎn)易ASP.NET MVC網(wǎng)站并允許數(shù)據(jù)庫遷移

瀏覽:178日期:2022-06-08 10:02:38

本篇使用EF Code First搭建一個(gè)簡(jiǎn)易ASP.NET MVC 4網(wǎng)站,并允許數(shù)據(jù)庫遷移。

創(chuàng)建一個(gè)ASP.NET MVC 4 網(wǎng)站。

在Models文件夾內(nèi)創(chuàng)建Person類。

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

在Controls文件夾內(nèi)創(chuàng)建PersonController,選擇使用Entity Framework的模版、模型類,創(chuàng)建數(shù)據(jù)上下文類,如下:

點(diǎn)擊"添加"后,除了在Controls文件夾內(nèi)多了PersonController,在Models文件夾中多了PersonContext類,如下:

using System.Data.Entity;namespace MvcApplication1.Models{    public class PersonContext : DbContext    {// 您可以向此文件中添加自定義代碼。更改不會(huì)被覆蓋。// // 如果您希望只要更改模型架構(gòu),Entity Framework// 就會(huì)自動(dòng)刪除并重新生成數(shù)據(jù)庫,則將以下// 代碼添加到 Global.asax 文件中的 Application_Start 方法。// 注意: 這將在每次更改模型時(shí)銷毀并重新創(chuàng)建數(shù)據(jù)庫。// // 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多了如下配置,選擇了默認(rèn)的localdb數(shù)據(jù)庫。

  <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這個(gè)幾個(gè)視圖文件。

現(xiàn)在,我們想啟動(dòng)EF的自動(dòng)遷移功能。點(diǎn)擊"工具"-"庫程序包管理器"-"程序包管理器控制臺(tái)",輸入enable-migrations:

在根目錄下多了一個(gè)Migrations文件夾,以及生成了一個(gè)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" }    //    );    //}    }}

以上,我們可以添加一些種子數(shù)據(jù)。

現(xiàn)在需要把種子數(shù)據(jù)遷移到數(shù)據(jù)庫,在"程序包管理器控制臺(tái)",輸入add-migration initial

此時(shí),在Migrations文件夾內(nèi)多了201502100756322_initial類,記錄了本次遷移的動(dòng)作。

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

最后別忘了要更新數(shù)據(jù)庫,在"程序包管理器控制臺(tái)",輸入update-database:

這時(shí)候,瀏覽/Person/Index,能實(shí)現(xiàn)所有的增刪改功能。

如果這時(shí)候,我們希望在Person中增加一個(gè)屬性,比如類型為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; }    }

我們?nèi)绾胃嬖V數(shù)據(jù)庫呢?

還是在"程序包管理器控制臺(tái)",輸入add-migration 名稱

此時(shí),在Migrations文件夾內(nèi)多了201502100812315_addedage類,記錄了本次遷移的動(dòng)作。

最后,還在"程序包管理器控制臺(tái)",輸入update-database以更新數(shù)據(jù)庫。

為了讓視圖與當(dāng)前Person類同步,可以先后刪除Person文件夾和PersonController控制器,再重新創(chuàng)建PersonController控制器,選擇使用Entity Framework的模版、Person類,PersonContext上下文類。

至此,簡(jiǎn)單體驗(yàn)了EF Code First創(chuàng)建數(shù)據(jù)庫并實(shí)現(xiàn)數(shù)據(jù)庫遷移的方便之處。

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

標(biāo)簽: ASP.NET
主站蜘蛛池模板: 中文字幕免费在线视频 | 色国产精品 | 国产综合色在线视频播放线视 | 日本人一级毛片免费完整视频 | 999久久66久6只有精品 | 青青自拍视频一区二区三区 | 同性男男黄h片在线播放免费 | 动漫男女交性动漫网站 | 亚洲永久中文字幕在线 | 国产黄色片在线看 | 精品欧美一区二区精品久久 | 欧美成人免费全部观看在线看 | 中文字幕亚洲综合久久202 | 久久久久亚洲香蕉网 | 2020国产成人精品免费视频 | 国产麻豆精品在线 | 欧洲欧美人成免费观看 | 成人卡通精品卡通动漫第一页 | 在线观看一级毛片免费 | 国产永久福利 | 久久本道综合色狠狠五月 | 久久99热狠狠色一区二区 | 色综合久久手机在线 | 国产大片免费看 | 亚洲六月丁香六月婷婷蜜芽 | 成人免费视频一区二区 | 黄色三级在线视频 | 鲁丝片一区二区三区免费 | 日韩中文字幕高清在线专区 | 国产区视频 | 日韩在线视频网 | 欧美一区欧美二区 | 久久精品国产久精国产果冻传媒 | 91精品国产三级在线观看 | 午夜影视水蜜桃网站 | 91精品视频在线观看免费 | 澳门一级特黄录像免费播黄 | 婷婷久久激情啪啪 | 中文字幕在线观看日韩 | 国产小视频精品 | 欧美日韩亚洲综合久久久 |