您的位置:首页 > 编程语言 > ASP

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

2015-01-04 21:55 375 查看
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语句,实现程序启动时初始化数据库数据。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息