《EF Core》实际上已经能够告一段落了,可是感受还有一点点意犹未尽。因此决定分享一下,我的在实际开发中使用EF Core的一些经验和使用的扩展包。sql
正如这小节题目所言,EF Core是支持异步操做的,但实际可用集中在SaveChanges和异步查询这两个方法上。数据库
具体方法声明以下:编程
public virtual System.Threading.Tasks.Task<int> SaveChangesAsync (System.Threading.CancellationToken cancellationToken = null);
public virtual System.Threading.Tasks.Task<TEntity> FindAsync<TEntity> (params object[] keyValues) where TEntity : class;
public virtual System.Threading.Tasks.Task<TEntity> FindAsync<TEntity> (object[] keyValues, System.Threading.CancellationToken cancellationToken) where TEntity : class;
public virtual System.Threading.Tasks.Task<object> FindAsync (Type entityType, params object[] keyValues);
public virtual System.Threading.Tasks.Task<object> FindAsync (Type entityType, object[] keyValues, System.Threading.CancellationToken cancellationToken);
这五个方法分别是SaveChanges的异步版,和Find的异步版。两种方法都支持传入一个取消令牌(这部份内容须要等后期的《C# 异步编程系列》里介绍)。数组
返回一个Task,而后按照Task进行执行就行。app
DbContext 也提供了Add/AddRange的异步方法,可是这组方法的异步版须要数据库的支持,并非一个通用的方法,因此就没有提。框架
var context = new DefaultContext("Data Source=./blogging1.db");
var task1 = context.FindAsync<SingleModel>(1);
var result = task1.Result;
var task2 = context.SaveChangesAsync();
这两个任务是建立一个热启动任务,也就是不用手动调用 Run方法。异步
回到数据查询来,查询的异步支持方法组是来自于Linq,可是底层来源于数据访问接口。ide
简单的实例:异步编程
var task3 = context.Set<SingleModel>().Where(t => true).ToListAsync();
当获取task3结果的时候,会强制等待任务完成执行。post
咱们知道using关键字一般用来引入命名空间,固然微软引入了另一种用法。对于EF Core的DbContext,框架推荐在用完以后将上下文销毁。而咱们每次使用必须都进行手动销毁。
若是咱们在使用try/catch/finally进行捕获异常的时候,须要在finally里放资源释放的代码。若是资源得不到正确及时的释放会出现更多的问题。
为了改善这种现状,微软便添加了using关键字的另一种用法。
using (var context = new DefaultContext("Data Source=./blogging1.db"))
{
// 使用 context
}
以上实例代码中using的含义是声明一个context做用于两个大括号之间,当两个大括号之间的代码执行完成后,会自动调用context.Dispose()方法。
using关键字的机制不会由于中途返回而不执行 context.Dispose(),也不会由于中间被抛出异常不执行。using的使用并不局限于实现IDisposable接口的对象,其余的对象也能够使用。
微软为SQLite和SQL Server提供了默认的数据库链接程序,其中 SQLite的是:
Microsoft.EntityFrameworkCore.Sqlite
SQL Server是:
Microsoft.EntityFrameworkCore.SqlServer
其余的经常使用数据库都是由三方提供,如下是一些常见的链接程序包和数据库名称:
NuGet 程序包 | 支持的数据库引擎 | 维护商/供应商 |
---|---|---|
Npgsql.EntityFrameworkCore.PostgreSQL | postgresql | Npgsql 开发团队 |
Pomelo.EntityFrameworkCore.MySql | MySQL、MariaDB | Pomelo Foundation 项目 |
Devart.Data.MySql.EFCore | MySQL 5 及以上版本 | DevArt |
Devart.Data.Oracle.EFCore | Oracle DB 9.2.0.4 及更高版本 | DevArt |
Devart.Data.PostgreSql.EFCore | PostgreSQL 8.0 及以上版本 | DevArt |
Oracle.EntityFrameworkCore | Oracle DB 11.2 及更高版本 | Oracle |
在EF 4的年代,EF自己不支持对批量数据的支持。后续慢慢增长了对数组的处理,包括增删。
可是随着时代的发展,数据量愈来愈大。因此仅仅是数组不能知足实际需求了。
如今给你们推荐一个插件:
Z.EntityFramework.Plus.EFCore
这个插件能够扩展DbContext的功能,使其支持对查询结果的操做:
var ctx = new DbContext();
var date = DateTime.Now.AddYears(-2);
ctx.Users.Where(x => x.LastLoginDate < date)
.Delete();
// DELETE using a BatchSize
var date = DateTime.Now.AddYears(-2);
ctx.Users.Where(x => x.LastLoginDate < date)
.Delete(x => x.BatchSize = 1000);
固然,还有更多的特色,之后在ASP.NET Core篇再为你们介绍。
EF Core到目前为止已经结束了,下一篇将开始探索一下Nhibernate或者Dapper吧。OK,C#的数据访问篇里的大头基本完成了。
下一个系列,小伙伴们打算看什么?预计是开始ASP.NET Core 系列了。