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语句,实现程序启动时初始化数据库数据。
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语句,实现程序启动时初始化数据库数据。
相关文章推荐
- 一道面试试题:试介绍ASP.NET页面之间数据传递的几种方法
- 介绍ASP.NET页面之间数据传递的几种方法,并介绍一些这些方法的优缺点?
- ASP.NET从数据库中取出数据添加到xml中方法
- asp.net 不用控件 循环输出数据库数据的方法
- 在ASP.NET应用启动的时候初始化的几种方法
- asp.net的几种简单连接数据库方法
- 关于asp.net网站发布后,使用登录控件和注册控件时出现“数据库只读,无法进行数据更新”的解决方法
- 用ASP.NET和C#连接数据库的几种方法
- ASP.NET页面间数据传递的几种方法
- ASP.NET页面间数据传递的几种方法(it168)
- 在ASP.NET应用启动的时候初始化的几种方法
- asp.net导出数据到Excel的几种方法(3/3)
- Asp.Net中几种常见的方法批量显示数据
- asp.net导出数据到Excel的几种方法(3/3)
- 用ASP.NET和C#连接数据库的几种方法
- 细说ASP.NET页面间数据传递的几种方法
- ASP.Net应用深入系列(一):GridView行绑定时取得某个数据列的几种方法比较
- ASP.NET-GridView数据绑定的几种方法
- asp.net导出数据到Excel的几种方法(2/3)
- asp.net导出数据到Excel的几种方法(1/3)