EF6中可以直接根据代码模型生成数据库Database.SetInitializer即可

在EFCore中如何实现呢?

这项功能放在了DatabaseFacade对象中,传入数据库上下文对象实例化到一个DatabaseFacade对象

可以看到DatabaseFacade有几个方法:

获取所有迁移的migraion数据:GetMigrations

获取待迁移的migration数据 :GetPendingMigrations

获取已经操作的migration数据:GetAppliedMigrations

适配migration: Migrate

这中间有一个坑:efcore 貌似还不能根据模型生成数据库,而是要先添加migrations的文件,然后才能适配数据库

这里我添加了一个XXXX字段,按照正常的流程:我们需要执行命令:

dotnet ef migrations add addxxxxxx

dotnet ef database update

EFCore中的自动适配数据库的前提是添加好 新增变量的migrations文件,实际上只是efcore只帮助了我们实现了dotnet ef database update的操作

首先先操作下:dotnet ef migrations add addxxxxxx

这里我写了一个简单的中间件来说明下:

通过注册服务,添加usermap引用

 /// <summary>
/// liyouming add 20180508
/// </summary>
/// <typeparam name="T">(context)上下文对象</typeparam>
/// <param name="service">扩展服务</param>
/// <param name="optionsAction">配置</param>
/// <returns></returns>
public static IServiceCollection AddEFMigrations<T>(this IServiceCollection service, Action<DbContextOptionsBuilder> optionsAction) where T : DbContext
{
service.AddDbContext<T>(optionsAction);
var serviceProvider = service.BuildServiceProvider();
service.AddSingleton<IEFMigrationsContext>(new EFMigrationsContext(serviceProvider.GetRequiredService(typeof(T)) as DbContext));
return service;
}

这里我们需要指导上下文对象T,并将该对象放到自定义的服务 IEFMigrationsContext 去处理下

然后扩展下IApplicationBuilder

public static IApplicationBuilder UseEFMigraions(
this IApplicationBuilder builder,string pathstring)
{
builder.Map(new Microsoft.AspNetCore.Http.PathString(pathstring), app => {
app.UseMiddleware<EFMigrationsMiddleware>(pathstring);
});
return builder;
}

比较简单,需要map下地址,当我们访问的时候进入到固定页面操作

 public class EFMigrationsMiddleware
{
private readonly RequestDelegate _next;
private readonly string _pathstring;
private IEFMigrationsContext _migrationsContext; public EFMigrationsMiddleware(RequestDelegate next, string pathstring, IEFMigrationsContext migrationsContext)
{
if (next == null)
{
throw new Exception(nameof(next));
}
_next = next;
_pathstring = pathstring;
_migrationsContext = migrationsContext; } public async Task Invoke(HttpContext context)
{
if (context.Request.PathBase == _pathstring)
{
var list = _migrationsContext.GetPendingMigrations();
_migrationsContext.AutoMigration();
string strli = string.Empty;
foreach (var item in list)
{
strli += "<li>" + item + "</li>";
}
await context.Response.WriteAsync("<html><body><ul>" + strli + "</ul></body></html>");
}
else
{
await _next(context);
}
return; }
}

下面直接实现接口方法就ok了,存在待更新的migrations就执行更新

public void AutoMigration()
{
if (databaseFacade.GetPendingMigrations().Any())
{
//执行迁移
databaseFacade.Migrate();
} }

下面来说下使用方式:跟原有的dbcontext使用方式一样,配置好你的上下文对象配置

注册服务:

 services.AddEFMigrations<UserDbContext>(optionsBuilder =>
{
var _userappsetting = Configuration.Get<UserAppSetting>();
if (_userappsetting == null)
{
throw new Exception("数据库连接字符串未配置");
}
switch (_userappsetting.DbType)
{
case : optionsBuilder.UseSqlServer(_userappsetting.UserConnectionString, sqlserver =>
{
sqlserver.MigrationsAssembly(_migrationAssablyName);
sqlserver.UseRelationalNulls();
sqlserver.UseRowNumberForPaging(); });
break;
case :
optionsBuilder.UseMySQL(_userappsetting.UserConnectionString, mysql =>
{
mysql.MigrationsAssembly(_migrationAssablyName);
mysql.UseRelationalNulls();
});
break;
default:
optionsBuilder.UseSqlServer(_userappsetting.UserConnectionString, sqlserver =>
{
sqlserver.MigrationsAssembly(_migrationAssablyName);
sqlserver.UseRelationalNulls();
sqlserver.UseRowNumberForPaging();
});
break;
}
});

AddEFMigrations

添加Configure

 app.UseEFMigraions("/Migrations");

下面访问下:/Migrations ,这里上面的代码中我先获取了待更新的migraions 方便验证,这里可以看到待验证的migraions是我新添加 addxxxxxxx

下面我们来检查数据生成情况: 已经生成了 XXXXX字段

如果能不操作dotnet ef migrations add addxxxxxx就好了,感觉还是有点鸡肋~~~

EFCore CodeFirst 适配数据库的更多相关文章

  1. EF CodeFirst 创建数据库

    最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精    话说EF支持三种模式:Code First   M ...

  2. NetCore2.0下使用EF CodeFirst创建数据库

    本文所使用的VS版本:VS2017 15.3.0 首先新建一个.net core项目  取名NetCoreTask 使用模型视图控制器方式 新建Model层 在Model层下新建一个user实体类 1 ...

  3. 6.翻译系列:EF 6 Code-First中数据库初始化策略(EF 6 Code-First系列)

    原文链接:http://www.entityframeworktutorial.net/code-first/database-initialization-strategy-in-code-firs ...

  4. 如何从40亿整数中找到不存在的一个 webservice Asp.Net Core 轻松学-10分钟使用EFCore连接MSSQL数据库 WPF实战案例-打印 RabbitMQ与.net core(五) topic类型 与 headers类型 的Exchange

    如何从40亿整数中找到不存在的一个 前言 给定一个最多包含40亿个随机排列的32位的顺序整数的顺序文件,找出一个不在文件中的32位整数.(在文件中至少确实一个这样的数-为什么?).在具有足够内存的情况 ...

  5. 一个支持DbFirst、ModelFirst和CodeFirst的数据库小工具DbTool

    DbTool 一个支持DbFirst.ModelFirst和CodeFirst的数据库工具. 简介 这是一个针对 SqlServer 数据库和 C# 开发语言的小工具,可以利用这个小工具生成数据库表对 ...

  6. .NetCore 使用Jenkins发布多环境下的项目并适配数据库EFCore数据库更新及替换配置文件

    说明 1.git上的配置地址可能都是本地环境,提交到git server后怎么来使用发布不同环境? 2.关于EFCore本地数据库有更新的情况 添加了 Migrations文件 怎么在构建的时候去更新 ...

  7. EFCore CodeFirst模型迁移生成数据库备注(mysql)

    重写Mysql下sql脚本生成器 using Framework.NetCore.Extensions; using Framework.NetCore.Models; using Microsoft ...

  8. 使用EF CodeFirst 创建数据库

    EntityFramework 在VS2015添加新建项时,选择数据->ADO.NET 实体数据模型,有一下选项 来自数据库的EF设计器,这个就是我们最常用的EntityFramework设计模 ...

  9. asp.net mvc CodeFirst模式数据库迁移步骤

    利用Code First模式构建好基本的类后,项目也开始搭建完毕并成功运行,而且已经将数据库表结构自动生成了. 但是,我有新的类要加入,有字段需要修改,那怎么办呢,删库,跑路 ?  哈哈 利用数据库迁 ...

随机推荐

  1. 位运算卷积-FWT

    问题 给出两个幂级数 \(f,g\) ,求 \[ h=\sum _i\sum _jx^{i\oplus j}f_ig_j \] 其中 \(\oplus\) 是可拆分的位运算. 算法 由于位运算具有独立 ...

  2. AtCoder Grand Contest 030 自闭记

    A:阅读. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> ...

  3. 关于链表的总结(C++循环实现)

    0.目录 1.链表的基本操作 1.1 结点定义 1.2 创建链表 1.3 销毁链表 1.4 打印链表 1.5 获取链表长度 2.结点的基本操作 2.1 删除结点 2.2 查找结点 3.面试题 3.1 ...

  4. 【刷题】LOJ 6002 「网络流 24 题」最小路径覆盖

    题目描述 给定有向图 \(G = (V, E)\) .设 \(P\) 是 \(G\) 的一个简单路(顶点不相交)的集合.如果 \(V\) 中每个顶点恰好在 \(P\) 的一条路上,则称 \(P\) 是 ...

  5. Fib的奇怪定理 : gcd(F[n],F[m])=F[gcd(n,m)]

    引理1:gcd(F[n],f[n-1])=1 因为 F[n]=f[n-1]+F[n-2] 所以 gcd(F[n],f[n-1]) = gcd(F[n-1]+F[n-2],F[n-1]) gcd的更损相 ...

  6. 解题:APIO 2018 铁人两项

    题面 建立圆方树,考虑所有路径,发现路径上原来的点双(现在的方点)里的点都可以做中间点.但是路径上被方点夹着的圆点被计重了,要扣掉:枚举的两个端点也被算进去了,要扣掉.所以直接将方点权值设为点双大小, ...

  7. bzoj 4328 始祖鸟

    4328: JSOI2012 始祖鸟 Time Limit: 10 Sec  Memory Limit: 256 MBSec  Special JudgeSubmit: 76  Solved: 52[ ...

  8. 错误日志收集sentry的安装与简单使用

    通过官方文档https://docs.sentry.io/可以得知,安装服务有两种方式,一种是使用Python,这种方式个人感觉比较麻烦.于是选择了第二种方式:使用docker. 我是在Windows ...

  9. Python中的ujson模块

    听说ujson比json模块快了很多,特来一试: # -*- coding: utf-8 -*- import json import ujson import time def cost_time( ...

  10. bzoj千题计划233:bzoj 1304: [CQOI2009]叶子的染色

    http://www.lydsy.com/JudgeOnline/problem.php?id=1304 结论1:根节点一定染色 如果根节点没有染色,选择其子节点的一个颜色,那么所有这个颜色的子节点都 ...