EF Core中高效批量删除、更新数据的Zack.EFCore.Batch发布三个新特性

Zack.EFCore.Batch是一个支持在Entity Framework Core中高效删除和更新数据的开源库。我们知道,EF Core中不支持高效的删除和更新数据,所有的更新和操作都是逐条数据处理。比如,如果使用如下的语句删除实现“删除所有价格大于10元的书“:

ctx.RemoveRange(ctx.Books.Where(b=> b.Price > 33))

那么,EntityFramework Core会先执行Select * from books where price>33,然后再对于每一条数据执行delete from books where id=@id进行删除。EF Core中批量数据的更新原理也是类似。因此在EF Core中进行大量数据的批量删除、更新效率是比较低的。

为了能够实现 “一句SQL实现数据的删除、更新“,我开发了开源项目Zack.EFCore.Batch,这个开源项目实现了如下批量删除的写法:

await ctx.DeleteRangeAsync<Book>(b => b.Price > n || b.AuthorName =="zack yang");

 上面的C#代码就会执行如下的SQL语句,从而实现“一句SQL删除数据“的效果:

Delete FROM[T_Books] WHERE ([Price] > @__p_0) OR ([AuthorName] = @__s_1)

  这个开源项目使用EF Core实现SQL语句的翻译,因此只要EF Core支持的数据库,对应的Linq操作都可以实现翻译成对应的方言SQL,比如下面的批量更新操作的Linq代码:

await ctx.BatchUpdate<Book>().Set(b => b.Price, b => b.Price + 3).Set(b => b.Title, b => s).Set(b =>b.AuthorName,b=>b.Title.Substring(3,2)+b.AuthorName.ToUpper()).Set(b => b.PubTime, b => DateTime.Now).Where(b => b.Id > n || b.AuthorName.StartsWith("Zack"))
.ExecuteAsync();

 在SQL Server数据库下就会翻译成一条Update语句,如下:

Update [T_Books]SET [Price] = [Price] + 3.0E0, [Title] = @__s_1, [AuthorName] =COALESCE(SUBSTRING([Title], 3 + 1, 2), N'') + COALESCE(UPPER([AuthorName]),N''), [PubTime] = GETDATE()
WHERE ([Id] >@__p_0) OR ([AuthorName] IS NOT NULL AND ([AuthorName] LIKE N'Zack%'))

 经历用户几个月的使用和反馈issue,目前项目已经升级到1.4.3版,支持SQLServer、MySQL、PostgreSQL、Oracle、SQLite数据库。理论上来讲,只要EF Core支持的数据库,Zack.EFCore.Batch都可以支持。如果您有其他数据库需要支持,请和我联系。

除了已有的特性之外,Zack.EFCore.Batch新版增加了如下特性。

 

特性一、基于实体关系的数据过滤

    在过滤条件中支持实体之间的关系。例如:

ctx. DeleteRangeAsync<Article>(a=>a.Comments.Any(c=>c.Message.Contains(“History”))
||a.Author.BirthDay.Year<2000);

 特性二、支持数据的批量插入

可以用如下的方式进行高效的批量插入:

List<Book> books = new List<Book>();
for (int i = 0; i < 100; i++)
{books.Add(newBook { AuthorName = "abc" + i, Price = new Random().NextDouble(),PubTime = DateTime.Now, Title = Guid.NewGuid().ToString() });
}
using (TestDbContext ctx = newTestDbContext())
{ctx.BulkInsert(books);
}

       BulkInsert()底层使用各个数据库的BulkCopy机制实现数据插入,因此插入效率非常高。目前有如下两个缺点:不支持关联数据的自动插入,对于关联的对象,请同样调用BulkInsert()进行插入;由于PostgreSQL的.NET Core Provider还没有支持BulkCopy,所以目前Zack.EFCore.Batch暂不支持PostgreSQL,我后面再去想办法解决。

 

特征三、支持Take()、Skip()来限制删除和更新数据的范围

       批量删除和批量更新都支持通过Take()、Skip()来实现部分删除和部分更新,例子代码如下:

await ctx.Comments.Where(c =>c.Article.Id == id).Skip(3)
.DeleteRangeAsync<Comment>(ctx);
await ctx.Comments.Where(c =>c.Article.Id == id).Skip(3).Take(10)
.DeleteRangeAsync<Comment>(ctx);
await ctx.Comments.Where(c =>c.Article.Id == id).Take(10)
.DeleteRangeAsync<Comment>(ctx);awaitctx.BatchUpdate<Comment>().Set(c => c.Message, c => c.Message +"abc").Where(c=> c.Article.Id == id).Skip(3).ExecuteAsync();await ctx.BatchUpdate<Comment>().Set(c=> c.Message, c => c.Message + "abc").Where(c=> c.Article.Id == id).Skip(3).Take(10).ExecuteAsync();
awaitctx.BatchUpdate<Comment>().Set(c => c.Message, c => c.Message +"abc").Where(c => c.Article.Id == id).Take(10).ExecuteAsync();

 

具体用法请访问开源项目地址:

https://github.com/yangzhongke/Zack.EFCore.Batch

NuGet地址:https://www.nuget.org/packages/Zack.EFCore.Batch/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/301827.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2012年,总结

2012年&#xff0c;神奇又平凡的一年。玛雅人的世界末日被普通的一天击破&#xff0c;自此买蜡烛的人就可以每天点着蜡烛做饭和炒菜了&#xff0c;用的还是当初囤积的食盐。 2012年&#xff0c;我就这样平淡的毕业了。就这样上班了&#xff0c;一切还没准备妥当&#xff0c;直到…

python pytest allure_python测试框架pytest和测试报告allure的联合使用-----测试套件

最近采用jenkinspythonpytestallure写了一些自动化测试用例。碰到这样一种场景&#xff1a;如果我创建了2个测试任务&#xff0c;测试任务1包含2个测试用例test_a.py和test_b.py&#xff0c;测试任务2包含一个测试用例test_c.py。一. 常规操作假设我的代码目录结构有如下3个测试…

那天,我无意间瞟了眼程序员的桌面……

全世界只有3.14 % 的人关注了数据与算法之美爱因斯坦曾说过“要是乱糟糟的桌面意味着杂乱无章的脑袋&#xff0c;那空白桌面意味着什么呢&#xff1f;似乎很多在某些领域拥有天赋的人都不喜欢干净整洁的桌面&#xff0c;包括乔布斯和扎克伯格也是&#xff0c;甚至有的人一看到整…

.Net Core with 微服务 - Ocelot 网关

上一次我们通过一张架构图&#xff08;.Net Core with 微服务 - 架构图&#xff09;来讲述了微服务的结构&#xff0c;分层等内容。从现在开始我们开始慢慢搭建一个最简单的微服务架构。这次我们先用几个简单的 web api 项目以及 ocelot 网关项目来演示下网关是如何配置&#x…

GNU ARM 汇编指令[转载]

http://blog.sina.com.cn/s/blog_59b189220100au1k.html 第一部分 Linux下ARM汇编语法尽管在Linux下使用C或C编写程序很方便&#xff0c;但汇编源程序用于系统最基本的初始化&#xff0c;如初始化堆栈指针、设置页表、操作 ARM的协处理器等。初始化完成后就可以跳转到C代码执行…

android java 8_四个库,让你在 Android 中启用 Java 8 功能

Java 8 的推出引入很多革命性变化&#xff0c;加入了函数式编程的特征&#xff0c;使基于行为的编程成为可能&#xff0c;同时简化了各种设计模式的实现方式&#xff0c;是 Java 有史以来最重要的更新。自 Android N 之后&#xff0c;由于 Jack&Jill 编译工具链的存在&…

NET问答: 如何将十六进制的 #FFDFD991 转成 C# 中的 Color 类?

咨询区 viky&#xff1a;请问如何将一个16进制的 color code 转成 C# 中的 Color &#xff1f;我的业务场景中需要从文件读取一个 hex color code&#xff0c;然后我需要将该 code 转成 System.Windows.Media.Color 实例&#xff0c;不知道 .NET Framework 中是否有相关的支持类…

60 Minutes专访李开复:泛人工智能可能永远实现不了

全世界只有3.14 % 的人关注了数据与算法之美尽管你听说过人工智能&#xff0c;但机器仍然无法像人类一样思考&#xff0c;但在过去的几年里&#xff0c;它们已经具备了学习的能力。突然之间&#xff0c;我们的设备睁开了眼睛和竖起了耳朵&#xff0c;汽车开始无人行驶。今天&am…

API之子窗口创建 (转)

子窗口的创建非常非常重要 步骤&#xff1a;1、新建窗口类&#xff0c;在窗口类中指名对应的自定义的窗口过程。窗口类类名要唯一&#xff0c;它 是各窗口类相互区别的标识。注意&#xff0c;类名或为静态变量&#xff0c;或为全局变量&#xff0c;因为程 序随时都用他们。…

java 支付宝 退款_Java 支付宝支付,退款,单笔转账到支付宝账户(支付宝支付)

最近一直在接触第三方,刚接入完支付宝的API做一下总结,个人能力薄弱有不对的地方望指教. 做的是一个小型电商项目,所以会接入第三方的支付和登入功能, 第一次接入第三方撸了很多官方文档.然后创建应用选择需要接入的功能,有些应用是需要签约的签约就好了审核蛮快的.以上应用申…

DB排行榜更新,.NET Core+MySQL成主流!

上图是DB-Engines数据库流行度最新排行榜&#xff0c;Oracle、MySQL、SQLServer虽几经下滑&#xff0c;然而还是遥遥领先的前三名。后起之秀PostgreSQL和MongoDB持续增长&#xff0c;然而在体量上还相差甚远&#xff0c;可以预见这些年&#xff0c;三大关系型数据库的主流地位是…

史上最惨锦鲤即将来袭!奖品堪比5年高考3年模拟!

全世界只有3.14 % 的人关注了数据与算法之美在锦鲤盛行的2018年我们超级数学建模也跟风来了一个“史上最惨锦鲤”活动为什么叫史上最惨锦鲤呢因为平常看一本数学书就已经头疼了何况我们奖品还是100本数学书试问除了学霸还有谁能承受这种殊荣巧的是最后的得主还真是一个学霸那就…

iOS开发  plist字段列表,很全

http://www.dreamingwish.com/dream-category/learning-note/iphone-learning-note http://www.dreamingwish.com/dream-2012/plist-field-list-it-is.html bundle字段 这些字段名都是XML中的名称&#xff0c;在xcode的属性编辑器中&#xff0c;名字并不相同 bundle目录中的属性…

java对象 序列化_Java基础之对象序列化

1. 什么是Java对象序列化Java平台允许我们在内存中创建可复用的Java对象&#xff0c;但一般情况下&#xff0c;只有当JVM处于运行时&#xff0c;这些对象才可能存在&#xff0c;即&#xff0c;这些对象的生命周期不会比JVM的生命周期更长。但在现实应用中&#xff0c;就可能要求…

NET问答: 到底是返回 null 好,还是 空集合 好?

咨询区 Omu&#xff1a;我是一个 C# 菜鸟&#xff0c;说实话&#xff0c;这个问题是一个非常困惑于我们这样初学者的一个问题&#xff0c;我想知道实际开发中的 最佳实践 应该是什么样的&#xff1f;回答区 user1228&#xff1a;如果要我选的话&#xff0c;我会用 空集合&#…

人工智能读心术

全世界只有3.14 % 的人关注了数据与算法之美对于许多无法发出声音的人来说&#xff0c;他们想说的话会通过某种信号隐藏在大脑中。人类无法直接破译这些信号。但是&#xff0c;最近有三个研究小组在“破译”这种大脑语言密码上取得了一定进展。Science杂志最新报道了哥伦比亚大…

非彼拉且数列的实现

递归算法实现&#xff1a; public static int F(int n) {if(n0 || n1){return 1;}else{return F(n-1)F(n-2)}} 迭代算法实现&#xff1a; public static int Fx(int n ) {int i 1;int j 1;int temp 0;if(n 0 || n1){return 1;}for(int k 2; k<n; k){temp i j;i j;j…

今日港股期货(港股期货今日交易动向)

港股期货收涨0.6% 首次突破31000点 今日港股期货大涨&#xff0c;形势一时看好。其中&#xff0c;恒生指数期货一度突破31000点关口&#xff0c;创出历史新高。分析人士表示&#xff0c;市场情绪积极&#xff0c;投资者对于全球经济复苏前景和中国经济增长的预期不断提高&…

春节特惠活动┃一张纸一幅图,竟然提高了10倍的学习和工作效率!?

▲数据汪特别推荐点击上图进入玩酷屋人类大脑的容量远远超出一般人的想象&#xff0c;时到21世纪的今天&#xff0c;我们对大脑的运用远远不够。大脑机能的使用率基于我们的思维模式&#xff0c;而思维导图正是开发大脑中最有效的利器&#xff01;之前小木给大家推荐了一套基于…

java class文件 代码_java_基础——用代码编译.java文件+加载class文件

java_基础——用代码编译.java文件加载class文件java_基础——用代码编译.java文件加载class文件【简单编译的流程】package com.zjm.www.test;import java.io.IOException;import javax.tools.JavaCompiler;import javax.tools.JavaCompiler.CompilationTask;import javax.too…