使用EF Code First搭建简易ASP.NET MVC网站并允许数据库迁移

 更新时间:2022年09月11日 14:35:46   作者:Darren Ji  
这篇文章介绍了使用EF Code First搭建简易ASP.NET MVC网站并允许数据库迁移的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

本篇使用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创建数据库并实现数据库迁移的方便之处。

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

相关文章

  • .NET原型模式讲解

    .NET原型模式讲解

    这篇文章主要为大家详细介绍了ASP.NET原型模式的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • asp.net基于windows服务实现定时发送邮件的方法

    asp.net基于windows服务实现定时发送邮件的方法

    这篇文章主要介绍了asp.net基于windows服务实现定时发送邮件的方法,结合实例形式较为详细的分析了asp.net调用Windows系统服务的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • asp.net访问Access数据库溢出错误

    asp.net访问Access数据库溢出错误

    asp.net访问Access数据库溢出错误,大家会的帮忙解决下啊。
    2009-07-07
  • .NET Core类库项目中读取appsettings.json配置的方法

    .NET Core类库项目中读取appsettings.json配置的方法

    ASP.NET Core是一个全新的Web开发平台,微软在它上面构建了MVC、SingalR、GRPC、Orleans这样广泛使用的Web框架,今天通过本文给大家详细介绍下.NET Core读取appsettings.json配置的方法,感兴趣的朋友一起看看吧
    2022-03-03
  • .Net WebApi中实现自动依赖注入的三种方法(最新推荐)

    .Net WebApi中实现自动依赖注入的三种方法(最新推荐)

    依赖关系注入 (DI) ,是一种软件设计模式,这是一种在类及其依赖项之间实现控制反转 (IoC) 的技术, .NET 中的依赖关系注入是框架的内置部分,与配置、日志记录和选项模式一样,这篇文章主要介绍了.Net WebApi中实现自动依赖注入的三种方法,需要的朋友可以参考下
    2024-03-03
  • .Net极限生产力之分表分库全自动化Migrations Code-First

    .Net极限生产力之分表分库全自动化Migrations Code-First

    这篇文章主要介绍了.Net极限生产力之分表分库全自动化Migrations Code-First,轻量级针对分表分库读写分离的解决方案,具有零依赖、零学习成本、零业务代码入侵适配
    2022-07-07
  • MVC 5 第二章 MVC5应用程序项目结构

    MVC 5 第二章 MVC5应用程序项目结构

    通过本章学习,你将了解到一个MVC 5应用程序的项目组成以及项目文件的相关信息,从而更好地架构设计出自己的项目结构。
    2014-06-06
  • .NET Core之微信支付之公众号、H5支付详解

    .NET Core之微信支付之公众号、H5支付详解

    这篇文章主要介绍了.NET Core之微信支付之公众号、H5支付篇,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • ASP.NET三层架构详解 如何实现三层架构

    ASP.NET三层架构详解 如何实现三层架构

    这篇文章主要为大家详细介绍了ASP.NET三层架构,如何实现三层架构,本文为大家揭晓,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • 解析微信支付的实现方法(.NET版)

    解析微信支付的实现方法(.NET版)

    由于微信的广泛利用,基于微信开发的一系列也应运而生,这篇文章主要介绍了解析微信支付的实现方法(.NET版),有兴趣的可以了解一下。
    2016-11-11

最新评论