电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

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

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

創(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ù)庫(kù),則將以下// 代碼添加到 Global.asax 文件中的 Application_Start 方法。// 注意: 這將在每次更改模型時(shí)銷毀并重新創(chuàng)建數(shù)據(jù)庫(kù)。// // 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ù)庫(kù)。

  <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)擊"工具"-"庫(kù)程序包管理器"-"程序包管理器控制臺(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ù)庫(kù),在"程序包管理器控制臺(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ù)庫(kù),在"程序包管理器控制臺(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ù)庫(kù)呢?

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

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

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

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

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

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

標(biāo)簽: ASP.NET
主站蜘蛛池模板: 包装机传感器-搅拌站传感器-山东称重传感器厂家-济南泰钦电气 | EDLC超级法拉电容器_LIC锂离子超级电容_超级电容模组_软包单体电容电池_轴向薄膜电力电容器_深圳佳名兴电容有限公司_JMX专注中高端品牌电容生产厂家 | 玻璃钢罐_玻璃钢储罐_盐酸罐厂家-河北华盛节能设备有限公司 | 阻燃剂-氢氧化镁-氢氧化铝-沥青阻燃剂-合肥皖燃新材料 | 河南mpp电力管_mpp电力管生产厂家_mpp电力电缆保护管价格 - 河南晨翀实业 | 专业的新乡振动筛厂家-振动筛品质保障-环保振动筛价格—新乡市德科筛分机械有限公司 | 智能汉显全自动量热仪_微机全自动胶质层指数测定仪-鹤壁市科达仪器仪表有限公司 | 河南空气能热水器-洛阳空气能采暖-洛阳太阳能热水工程-洛阳润达高科空气能商行 | 凝胶成像仪,化学发光凝胶成像系统,凝胶成像分析系统-上海培清科技有限公司 | 光环国际-新三板公司_股票代码:838504 | 东莞螺丝|东莞螺丝厂|东莞不锈钢螺丝|东莞组合螺丝|东莞精密螺丝厂家-东莞利浩五金专业紧固件厂家 | CE认证_FCC认证_CCC认证_MFI认证_UN38.3认证-微测检测 CNAS实验室 | 英思科GTD-3000EX(美国英思科气体检测仪MX4MX6)百科-北京嘉华众信科技有限公司 | 环压强度试验机-拉链拉力试验机-上海倾技仪器仪表科技有限公司 | 吉林污水处理公司,长春工业污水处理设备,净水设备-长春易洁环保科技有限公司 | 安徽免检低氮锅炉_合肥燃油锅炉_安徽蒸汽发生器_合肥燃气锅炉-合肥扬诺锅炉有限公司 | 广西正涛环保工程有限公司【官网】| 篮球架_乒乓球台_足球门_校园_竞技体育器材_厂家_价格-沧州浩然体育器材有限公司 | 南京技嘉环保科技有限公司-杀菌除臭剂|污水|垃圾|厕所|橡胶厂|化工厂|铸造厂除臭剂 | led冷热冲击试验箱_LED高低温冲击试验箱_老化试验箱-爱佩百科 | 水平垂直燃烧试验仪-灼热丝试验仪-漏电起痕试验仪-针焰试验仪-塑料材料燃烧检测设备-IP防水试验机 | 耐磨陶瓷管道_除渣器厂家-淄博浩瀚陶瓷科技有限公司 | 万家财经_财经新闻_在线财经资讯网 | 纯水设备_苏州皙全超纯水设备水处理设备生产厂家 | 中国玩具展_玩具展|幼教用品展|幼教展|幼教装备展 | 泵阀展|阀门展|水泵展|流体机械展 -2025上海国际泵管阀展览会flowtech china | 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 - 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 | 洗砂机械-球磨制砂机-洗沙制砂机械设备_青州冠诚重工机械有限公司 | 断桥铝破碎机_发动机破碎机_杂铝破碎机厂家价格-皓星机械 | 北京律师事务所_房屋拆迁律师_24小时免费法律咨询_云合专业律师网 | 河南包装袋厂家_河南真空袋批发价格_河南服装袋定制-恒源达包装制品 | 安徽千住锡膏_安徽阿尔法锡膏锡条_安徽唯特偶锡膏_卡夫特胶水-芜湖荣亮电子科技有限公司 | 慈溪麦田广告公司,提供慈溪广告设计。 | 玄米影院| 宿松新闻网 宿松网|宿松在线|宿松门户|安徽宿松(直管县)|宿松新闻综合网站|宿松官方新闻发布 | 无压烧结银_有压烧结银_导电银胶_导电油墨_导电胶-善仁(浙江)新材料 | 挨踢网-大家的导航!| 帽子厂家_帽子工厂_帽子定做_义乌帽厂_帽厂_制帽厂 | LNG鹤管_内浮盘价格,上装鹤管,装车撬厂家-连云港赛威特机械 | 电磁铁_小型推拉电磁铁_电磁阀厂家-深圳市宗泰电机有限公司 | 全自动固相萃取仪_高通量真空平行浓缩仪-勤业永为 |