ASP.NET的几种数据初始化方法:
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();
}
}
每次模型结构与数据库结构不同时,系统会自动执行SchoolInitializer方法,执行该方法时,会把原有数据表内的数据全部删除。
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类
c)
在Application的Web.config文件中加入databaseInitializer节点,告诉系统有这个初始化类。
若无需执行
databaseInitializer时
,可以在context节点加入属性:
disableDatabaseInitializ ation="true
"。
3、在
Global.asax.cs文件的
Application_Start方法中加入
Database.SetInitializer语句,实现程序启动时初始化数据库数据。