ASP.NET几种数据库数据初始化方法

本文介绍了ASP.NET中三种数据初始化的方法:使用CodeFirstMigrations功能、通过DbContext对象的Initializer类及在Global.asax.cs文件中设置Database.SetInitializer。每种方法都有详细的步骤说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ASP.NET的几种数据初始化方法:
1、利用 Code FirstMigrations功能。在Migrations目录的Configuration.cs文件中的Seed方法中,添加数据初始化代码。
  a) 首先,在库程序包管理控制台中输入:enable-migrations -ContextTypeNameMovies.Model.Movie,启动Migration功能。
  b) 在上述命令生成的Configuration.cs(Migrations目录下)文件中的Seed方法中添加模型初始值。例如:
   protected override voidSeed(StudyMVC5.Models.MovieDBContextcontext) 
   {
    context.Movies.AddOrUpdate(i =>i.Title, 
    new Movie { 
     Title = "When Harry Met Sally", 
     ReleaseDate =DateTime.Parse("1989-1-11"), 
     Genre = "Romantic Comedy",
     Rating = "PG", 
     Price = 7.99M });
   }

  c) 其后,在"程序包管理器控制台"中使用add-migration来创建数据库与模型同步的代码,然后用update-database同步数据库并初始化数据。
  用此方法会导致在执行update-database命令前对数据作的任何修改全部丢失

2、通过DbContext对象的Initializer类来实现。
  a) 首先,需要有一个继承于DbContext的对象,在此以SchoolContext为例。
   public class SchoolContext :DbContext 
   { 
    publicSchoolContext() : base("SchoolContext"){} 

    public DbSet Enrollments { get; set;} 
    protected override voidOnModelCreating(DbModelBuilder modelBuilder)
    {
     modelBuilder.Conventions.Remove(); 
    }
   }
  b) 然后创建一个SchoolInitializer类
       publicclass SchoolInitializer :System.Data.Entity.DropCreateDatabaseIfModelChanges
       {
          protected override voidSeed(SchoolContext context)
          {
             var enrollments = new List{
            new Enrollment{StudentID=1,CourseID=1050,Grade=Grade.A},
            new Enrollment{StudentID=1,CourseID=4022,Grade=Grade.C},
            new Enrollment{StudentID=1,CourseID=4041,Grade=Grade.B},
            new Enrollment{StudentID=2,CourseID=1045,Grade=Grade.B},
             };
             enrollments.ForEach(s =>context.Enrollments.Add(s));
             context.SaveChanges();
          }
       }
  c) 在Application的Web.config文件中加入databaseInitializer节点,告诉系统有这个初始化类。
      每次模型结构与数据库结构不同时,系统会自动执行SchoolInitializer方法,执行该方法时,会把原有数据表内的数据全部删除。
   若无需执行databaseInitializer时,可以在context节点加入属性:disableDatabaseInitialization="true"。

3、在Global.asax.cs文件的Application_Start方法中加入Database.SetInitializer语句,实现程序启动时初始化数据库数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值