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

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.DropCreateDatabaseIfMode lChanges
        {
            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语句,实现程序启动时初始化数据库数据。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值