经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » ASP.net » 查看文章
使用EF Code First搭建简易ASP.NET MVC网站并允许数据库迁移
来源:jb51  时间:2022/9/15 9:09:19  对本文有异议

本篇使用EF Code First搭建一个简易ASP.NET MVC 4网站,并允许数据库迁移。

创建一个ASP.NET MVC 4 网站。

在Models文件夹内创建Person类。

  1. public class Person
  2. {
  3. public int ID { get; set; }
  4. public string FirstName { get; set; }
  5. public string LastName { get; set; }
  6. }

在Controls文件夹内创建PersonController,选择使用Entity Framework的模版、模型类,创建数据上下文类,如下:

点击"添加"后,除了在Controls文件夹内多了PersonController,在Models文件夹中多了PersonContext类,如下:

  1. using System.Data.Entity;
  2. namespace MvcApplication1.Models
  3. {
  4. public class PersonContext : DbContext
  5. {
  6. // 您可以向此文件中添加自定义代码。更改不会被覆盖。
  7. //
  8. // 如果您希望只要更改模型架构,Entity Framework
  9. // 就会自动删除并重新生成数据库,则将以下
  10. // 代码添加到 Global.asax 文件中的 Application_Start 方法。
  11. // 注意: 这将在每次更改模型时销毁并重新创建数据库。
  12. //
  13. // System.Data.Entity.Database.SetInitializer(new System.Data.Entity.DropCreateDatabaseIfModelChanges<MvcApplication1.Models.PersonContext>());
  14. public PersonContext() : base("name=PersonContext")
  15. {
  16. }
  17. public DbSet<Person> People { get; set; }
  18. }
  19. }

在Web.config中的connectionStrings多了如下配置,选择了默认的localdb数据库。

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

在Views/文件夹中多了Create.cshtml, Delete.cshtml, Details.cshtml, Edit.cshtml, Index.cshtml这个几个视图文件。

现在,我们想启动EF的自动迁移功能。点击"工具"-"库程序包管理器"-"程序包管理器控制台",输入enable-migrations:

在根目录下多了一个Migrations文件夹,以及生成了一个Configuration类,如下:

  1. namespace MvcApplication1.Migrations
  2. {
  3. using System;
  4. using System.Data.Entity;
  5. using System.Data.Entity.Migrations;
  6. using System.Linq;
  7. internal sealed class Configuration : DbMigrationsConfiguration<MvcApplication1.Models.PersonContext>
  8. {
  9. public Configuration()
  10. {
  11. AutomaticMigrationsEnabled = false;
  12. }
  13. protected override void Seed(MvcApplication1.Models.PersonContext context)
  14. {
  15. // This method will be called after migrating to the latest version.
  16. // You can use the DbSet<T>.AddOrUpdate() helper extension method
  17. // to avoid creating duplicate seed data. E.g.
  18. //
  19. // context.People.AddOrUpdate(
  20. // p => p.FullName,
  21. // new Person { FullName = "Andrew Peters" },
  22. // new Person { FullName = "Brice Lambson" },
  23. // new Person { FullName = "Rowan Miller" }
  24. // );
  25. //
  26. }
  27. }
  28. }

以上,我们可以添加一些种子数据。

现在需要把种子数据迁移到数据库,在"程序包管理器控制台",输入add-migration initial

此时,在Migrations文件夹内多了201502100756322_initial类,记录了本次迁移的动作。

  1. namespace MvcApplication1.Migrations
  2. {
  3. using System;
  4. using System.Data.Entity.Migrations;
  5. public partial class initial : DbMigration
  6. {
  7. public override void Up()
  8. {
  9. CreateTable(
  10. "dbo.People",
  11. c => new
  12. {
  13. ID = c.Int(nullable: false, identity: true),
  14. FirstName = c.String(),
  15. LastName = c.String(),
  16. })
  17. .PrimaryKey(t => t.ID);
  18. }
  19. public override void Down()
  20. {
  21. DropTable("dbo.People");
  22. }
  23. }
  24. }

最后别忘了要更新数据库,在"程序包管理器控制台",输入update-database:

这时候,浏览/Person/Index,能实现所有的增删改功能。

如果这时候,我们希望在Person中增加一个属性,比如类型为int的Age属性。

  1. public class Person
  2. {
  3. public int ID { get; set; }
  4. public string FirstName { get; set; }
  5. public string LastName { get; set; }
  6. public int Age { get; set; }
  7. }

我们如何告诉数据库呢?

还是在"程序包管理器控制台",输入add-migration 名称

此时,在Migrations文件夹内多了201502100812315_addedage类,记录了本次迁移的动作。

最后,还在"程序包管理器控制台",输入update-database以更新数据库。

为了让视图与当前Person类同步,可以先后删除Person文件夹和PersonController控制器,再重新创建PersonController控制器,选择使用Entity Framework的模版、Person类,PersonContext上下文类。

至此,简单体验了EF Code First创建数据库并实现数据库迁移的方便之处。

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号