【ASP.NET Core快速入门】(十六)MVC开发:DbContextSeed初始化
2018-01-09 19:38
866 查看
前言
由于我们现在每次EF实体模型变化的时候每次都是手动更改,我们想通过代码的方式让他自动更新,或者程序启动的时候添加一些数据进去DbContextSeed初始化
首先,在Data文件夹下添加一个ApplicationDbContextSeed.cs初始化类using Microsoft.AspNetCore.Identity; using MvcCookieAuthSample.Models; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.Extensions.DependencyInjection; namespace MvcCookieAuthSample.Data { public class ApplicationDbContextSeed { private UserManager<ApplicationUser> _userManager; public async Task SeedAsync(ApplicationDbContext context, IServiceProvider services) { if (!context.Users.Any()) { _userManager = services.GetRequiredService<UserManager<ApplicationUser>>(); var defaultUser = new ApplicationUser { UserName="Administrator", Email="786744873@qq.com", NormalizedUserName="admin" }; var result= await _userManager.CreateAsync(defaultUser,"Password$123"); if (!result.Succeeded) { throw new Exception("初始默认用户失败"); } } } } }
那么如何调用呢?接下来我们写一个WebHost的扩展方法类WebHostMigrationExtensions.cs来调用ApplicationDbContextSeed方法
using Microsoft.AspNetCore.Hosting; using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; namespace MvcCookieAuthSample.Data { public static class WebHostMigrationExtensions { public static IWebHost MigrateDbContext<TContext>(this IWebHost host, Action<TContext, IServiceProvider> sedder) where TContext : DbContext { using (var scope=host.Services.CreateScope()) {//只在本区间内有效 var services = scope.ServiceProvider; var logger = services.GetRequiredService<ILogger<TContext>>(); var context = services.GetService<TContext>(); try { context.Database.Migrate(); sedder(context, services); logger.LogInformation($"执行DBContext {typeof(TContext).Name} seed执行成功"); } catch (Exception ex) { logger.LogError(ex, $"执行DBContext {typeof(TContext).Name} seed方法失败"); } } return host; } } }
那么我们程序启动的时候要怎调用呢?
要在Program.cs中执行
我们接下来把数据库删掉,然后启动程序运行一下
数据库已自动生成并插入数据
源码点击下载
相关文章推荐
- 【ASP.NET Core快速入门】(十四)MVC开发:UI、 EF + Identity实现、注册实现、登陆实现
- 【ASP.NET Core快速入门】(十五)MVC开发:ReturnUrl实现、Model后端验证 、Model前端验证
- 【ASP.NET Core快速入门】(九) RoutingMiddleware介绍以及MVC引入
- T4 模板: 为 ASP.NET MVC 开发人员快速入门指南
- 菜鸟入门【ASP.NET Core】14:MVC开发:UI、 EF + Identity实现、注册实现、登陆实现
- 菜鸟入门【ASP.NET Core】15:MVC开发:ReturnUrl实现、Model后端验证 、Model前端验证
- 在ASP.NET Core中使用Apworks快速开发数据服务
- 实现基于ASP.NET MVC快速开发平台
- Asp.net MVC 和 Comet 开发入门
- ASP.NET MVC 开源快速开发平台,我的实习学生妹也喜欢!
- ASP.NET MVC 5 学习教程:快速入门
- .NET Core实战项目之CMS 第二章 入门篇-快速入门ASP.NET Core看这篇就够了
- 【ASP.NET Core快速入门】(五)命令行配置、Json文件配置、Bind读取配置到C#实例、在Core Mvc中使用Options
- 【.NET Core】ASP.NET Core之IdentityServer4(1):快速入门
- ASP.NET Core 快速入门(实战篇)
- asp.net core跨平台开发从入门到实战文摘
- 学习: ASP.NET MVC开发入门-UI实现根据查询条件返回Model层的查询结果
- .NET Core快速入门教程 4、使用VS Code开发.NET Core控制台应用程序
- 步步为营:三层架构+ASP.NET MVC 架构的快速搭建(入门篇)
- 在ASP.NET Core中使用Apworks快速开发数据服务