由于之前接触Asp.Net MVC时看的速成版教程,并没有完善学习,断断续续发现了一些新知识,予以记录。
以前学习教程,当使用Code Firsrt创建表结构后,添加默认数据,但是尝试失败了,最近学习ABP框架,解决了这个问题,做笔记!
1.在EF仓库的Migrations/SeedData文件下创建文件,例:DefaultTestDataForTask
public class DefaultTestDataForTask
{
private readonly MyABPDbContext _context;
private static readonly List<Task> _tasks;
public DefaultTestDataForTask(MyABPDbContext context)
{
_context = context;
}
static DefaultTestDataForTask()
{
_tasks = new List<Task>()
{
new Task("Learning ABP deom", "Learning how to use abp framework to build a MPA application."),
new Task("Make Lunch", "Cook 2 dishs")
};
}
public void Create()
{
foreach (var task in _tasks)
{
if (_context.Tasks.FirstOrDefault(t => t.Title == task.Title) == null)
{
_context.Tasks.Add(task);
}
_context.SaveChanges();
}
}
}
2.在文件Migrations下的Configuration文件中添加配置
new InitialHostDbBuilder(context).Create();
经测试的确可以实现,但是一个尴尬问题,当你删除表中初始化数据时,还会自动创建,可以将预设种子文件的进行改造