浅析Entity Framework Core2.0的日志记录与动态查询条件
Entity Framework Core 2.0更新也已经有一段时间了,园子里也有不少的文章..
本文主要是浅析一下Entity Framework Core2.0的日志记录与动态查询条件
去年我写过一篇关于Entity Framework Core1.0和1.1的日志记录和事务的文章:
时过境迁..EF Core也更新到2.0了..
在日志记录方面,有了比较大的变化..所以我觉得还是需要学习学习
一、 Entity Framework Core2.0的日志记录
早在Entity Framework Core1.0 ,我们就使用相关的ILoggerProvider ILogger 这些基础接口类.来实现过日志记录.
在Entity Framework Core2.0 估计是为了配合ASP.NET Core的日志.所以对这些接口进行了更进一步的包装,也弃用了一些接口和类,如:IRelationalCommandBuilderFactory ,DbCommandLogData
但是Entity Framework Core2.0 在DbContextOptionsBuilder添加了新的扩展方法.UseLoggerFactory
看到LoggerFactory,研究过ASP.NET Core日志记录的同学,应该就很熟悉了..这是ASP.NET Core日志记录的工厂类.
也就是为什么我们如果在ASP.NET Core中注入自己的日志记录,也可以通过配置来记录相关的SQL操作的原因.
这里我们主要是直接只监控EF Core的日志.
代码如下:
public class BloggingContext : DbContext
{
public BloggingContext(DbContextOptions<BloggingContext> options)
: base(options)
{
this.Database.EnsureCreated();
}
//创建日志工厂
private static ILoggerFactory Mlogger =>new LoggerFactory()
.AddDebug((categoryName, logLevel) => (logLevel == LogLevel.Information) && (categoryName == DbLoggerCategory.Database.Command.Name))
.AddConsole((categoryName, logLevel) => (logLevel == LogLevel.Information) && (categoryName == DbLoggerCategory.Database.Command.Name)); protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
var loggerFactory =
optionsBuilder
.UseLoggerFactory(Mlogger) //注入日志工厂
.UseMySql(@"Server=1.1.1.1;database=666;uid=6666;pwd=88888;");
} public DbSet<Blog> Blogs { get; set; }
public DbSet<Post> Posts { get; set; }
}
我们直接创建一个日志工厂类,然后注入到EF Core上下文中即可.
这里作为例子,只将日志记录在了调试窗口..当然也可以记录在自己的文件中..具体请参考LoggerFactory的相关说明..
我们编写查询代码如下:
public List<string> GetList(string a)
{
var date = _bloggingContext.Blogs.Where(c => == ).ToList();
return new List<string>() { "LiLei", "ZhangSan", "LiSi" };
}
监控效果如下:

二、 Entity Framework Core2.0 动态Linq查询
Entity Framework Core2.0出来这么久了..Github上面也有很多相关的扩展类库..今天我们就来玩玩这个动态查询库
开源地址:https://github.com/StefH/System.Linq.Dynamic.Core/
这个库还是蛮强大的.支持.NET4.0+ 和 .NET Standard 标准.
这个库在nuget中分了几个版本.所以..
我们使用EF Core,所以需要引用它的 Microsoft.EntityFrameworkCore.DynamicLinq 这个库.
这个库针对IQueryable进行了动态条件的扩展..
官方例子的代码如下:
var query = db.Customers
.Where("City == @0 and Orders.Count >= @1", "London", )
.OrderBy("CompanyName")
.Select("new(CompanyName as Name, Phone)");
我们可以看到.where条件可以传递格式化字符串.包括排序与查询..都可以传入字符串的条件..
这样,我们写一些相对比较灵活的模块就可以使用了.比如一个表的查询字段.来源于另一个表.
下面我们来自己试试效果.
代码如下:
public List<string> GetList(string a)
{
// _bloggingContext.Blogs.Add(new Blog() { Url = "asd" });
// _bloggingContext.SaveChanges();
var date = _bloggingContext.Blogs.Where(c => == ).ToList();
var date2 = _bloggingContext.Blogs.Where("1==1").Select("new(Url)").ToDynamicList();
return new List<string>() { "LiLei", "ZhangSan", "LiSi" };
}
我们直接给一个恒成立的条件来查询所有的数据.
监控效果如下:

我们发现,这个库还是很强大的..
因为它是对IQueryable进行的扩展,所以没有数据库不支持的情况..只要有相关的驱动,就可以基于驱动来生成相关的SQL代码..(我这里访问的就是MySQL)
..
就到这里了.. EF core2.0已经完全可以用于生产环境了..虽然在之前的线路图中答应的事情..比如更方便的映射..比如分组..比如拦截..都延期到了2.1版本..但是这些并不影响它的强大~..
浅析Entity Framework Core2.0的日志记录与动态查询条件的更多相关文章
- ADO.NET Entity Framework CodeFirst 如何输出日志(EF 5.0)
ADO.NET Entity Framework CodeFirst 如何输出日志(EF4.3) 用的EFProviderWrappers ,这个组件好久没有更新了,对于SQL执行日志的解决方案的需求 ...
- 开发 ASP.NET vNext 续篇:云优化的概念、Entity Framework 7.0、简单吞吐量压力测试
继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之后, 关于云优化和版本控制: 我本想做一下MAC和LINUX的self-ho ...
- Entity Framework 5.0系列之Code First数据库迁移
我们知道无论是"Database First"还是"Model First"当模型发生改变了都可以通过Visual Studio设计视图进行更新,那么对于Cod ...
- 在Entity Framework 4.0中使用 Repository 和 Unit of Work 模式
[原文地址]Using Repository and Unit of Work patterns with Entity Framework 4.0 [原文发表日期] 16 June 09 04:08 ...
- 云优化的概念、Entity Framework 7.0、简单吞吐量压力测试
云优化的概念.Entity Framework 7.0.简单吞吐量压力测试 继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之 ...
- [EF2]Sneak Preview: Persistence Ignorance and POCO in Entity Framework 4.0
http://blogs.msdn.com/b/adonet/archive/2009/05/11/sneak-preview-persistence-ignorance-and-poco-in-en ...
- 精进不休 .NET 4.5 (12) - ADO.NET Entity Framework 6.0 新特性, WCF Data Services 5.6 新特性
[索引页][源码下载] 精进不休 .NET 4.5 (12) - ADO.NET Entity Framework 6.0 新特性, WCF Data Services 5.6 新特性 作者:weba ...
- Entity Framework 5.0
今天 VS2012 .net Framework 4.5 Entity Framework 5.0 三者共同发布了. ( EF5 Released ) 在介绍新特性之前,先与大家回顾一下EF版 ...
- Entity Framework 6.0 对枚举的支持/实体添加后会有主键反回
实验 直接上代码,看结果 实体类 [Flags] public enum FlagsEnum { Day = , Night = } public class EntityWithEnum { pub ...
随机推荐
- Spring之DAO一
前面博客把bean.aop简单了解了一下,今天主要是了解Spring中DAO层,如果使用传统的JDBC时需要创建连接.打开.执行sql.关闭连接这一系列的步骤,Spring框架对JDBC进行了封装,我 ...
- 云计算---openstack镜像制作
一:本地部署KVM 1.安装KVM 1.1安装须知 查看CPU是否支持kvm完全虚拟机. [root@LINUX ~]# grep "flags" /proc/cpuinfofla ...
- 豹哥嵌入式讲堂:ARM开发中有用的文件(1)- source文件
大家好,我是豹哥,猎豹的豹,犀利哥的哥.今天豹哥给大家讲的是嵌入式开发里的source文件种类. 众所周知,嵌入式开发属于偏底层的开发,主要编程语言是C和汇编.所以本文要讲的source文件主要指的就 ...
- Java集合(一) CopyOnWriteArrayList
CopyOnWriteArrayList 类分析 1. CopyOnWriteArrayList 其中底层实现存放数据是一个Object数组: private volatile transie ...
- 学习时用的软件最新 开发环境为Visual Studio 2010,数据库为SQLServer2005,使用.net 4.0开发。 超市管理系统
一.源码特点 1.采用典型的三层架构进行开发.模板分离,支持生成静态 伪静态..购物车.登陆验证.div+css.js等技术二.功能介绍 1.本源码是一个超市在线购物商城源码,该网上商城是给超市便利店 ...
- java数组去重
java数组去重 1.创建新数组,用于保存比较结果 2.设定随机数组最大最小值 3.开始去重 4.计算去重所需时间 package org.zheng.collection; import java. ...
- locust 参数,数据详解
参数 说明-h, –help 查看帮助-H HOST, –host=HOST 指定被测试的主机,采用以格式:http://10.21.32.33–web-host=WEB_HOST ...
- 使用trim_galore软件遇到的问题
我的原始测序数据是双端测序,在用trim_galore软件去接头的这一步,使用的命令行是 time nohup trim_galore R17002628-SKOV3-m6A_combined_R1. ...
- windows 运行banana
1 git clone 工程 2 安装 npm 3 执行 npm install -g bower
- thinkinginjava学习笔记08_接口
抽象类和抽象方法 抽象方法是指没有具体实现的方法,仅仅有方法的声明和没有方法体:使用abstract关键字定义一个抽象方法:包含抽象方法的类成为抽象类,如果一个类中包含抽象方法则必须使用abstrac ...