首页 科技正文

镇江人才在线:C# 数据操作系列 - 9. EF Core 完结篇

admin 科技 2020-05-19 32 0

0.前言

《EF Core》现实上已经可以告一段落了,然则感受另有一点点意犹未尽。以是决议分享一下,个人在现实开发中使用EF Core的一些履历和使用的扩展包。

1. EF Core的异步操作

正如这小节问题所言,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举行执行就行。

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,然则底层来源于数据接见接口。

简朴的实例:

var task3 = context.Set<SingleModel>().Where(t => true).ToListAsync();

当获取task3效果的时刻,会强制守候义务完成执行。

2. using的另一种用法

我们知道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接口的工具,其他的工具也可以使用。

3. EF Core的数据库接见插件

微软为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

4. EF Core的配件

在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篇再为人人先容。

5.后续

EF Core到目前为止已经竣事了,下一篇将最先探索一下Nhibernate或者Dapper吧。OK,C#的数据接见篇里的大头基本完成了。

下一个系列,小伙伴们计划看什么?预计是最先ASP.NET Core 系列了。

更多内容烦请关注我的博客《高先生小屋》

,

诚信娱乐

诚信娱乐(现:阳光在线官网)现已开放诚信在线手机版、诚信在线电脑客户端下载。诚信在线娱乐游戏公平、公开、公正,用实力赢取信誉。

版权声明

本文仅代表作者观点,
不代表本站Allbet的立场。
本文系作者授权发表,未经许可,不得转载。

评论