EntityFramework Core 5.0 VS SQLBulkCopy

【导读】EF Core 5.0伴随着.NET 5.0发布已有一段时日,本节我们来预估当大批量新增数据时,大概是多少区间我们应该考虑SQLBulkCopy而不是EF Core

SQLBulkCopy早出现于.NET Framework 2.0,将数据批量写入利用此类毫无疑问最佳,虽其来源任意,但此类仅适用于SQL Server,每个关系数据库都有其批量处理驱动,这里我们仅仅只讨论SQL Server

性能差异预估批量数据大小

首先给出我们需要用到的测试模型

public class User
{public int Id { get; set; }public string Name { get; set; }public DateTime Birth { get; set; }public string Email { get; set; }public string Phone { get; set; }
}

接下来我们则需要模拟数据,为伪造实际生产数据,这里我们介绍一个包Bogus,此包专用来伪造数据,一直在更新从未间断,版本也达到32,如下:

此包中有针对用户类的模拟,具体使用这里就不详细展开,我们构造一个方法来伪造指定数量的用户数据,如下:

private IEnumerable<User> GenerateUseres(int count)
{var profileGenerator = new Faker<User>().RuleFor(p => p.Name, v => v.Person.UserName).RuleFor(p => p.Birth, v => v.Person.DateOfBirth).RuleFor(p => p.Email, v => v.Person.Email).RuleFor(p => p.Phone, v => v.Person.Phone);return profileGenerator.Generate(count);
}

有了批量伪造数据,接下来我们再利用上下文去新增数据,然后分别打印伪造数据和新增成功所耗费时间,如下:

[HttpPost]
public async Task<IActionResult> GenerateInsert([FromQuery] int count = 1000)
{var s = new Stopwatch();s.Start();var users = GenerateUseres(count);var gererationTime = s.Elapsed.ToString();s.Restart();await _context.Users.AddRangeAsync(users);var insertedCount = await _context.SaveChangesAsync();return Ok(new{inserted = insertedCount,generationTime = gererationTime,insertTime = s.Elapsed.ToString()});
}

新增100条数据太小,这里我们直接从批量1000条数据开始测试,此时我们将看到所存储数据和实际数据完全一毛一样

通过SQL Server Profiler工具监控得到如下一堆语句

通过运行多次,当然也和笔记本配置有关(i7,6核12线程,内存16G),但还是可以预估批量新增1000条大概耗时为毫秒级,如下:

接下来我们试试新增1万条看看,耗时基本需要1秒,如下:

最后我们再来试试新增十万条数据试试,大概需要14秒才能完成

到了这里想必我们没有必要再往上增长数据,我们来看看利用SqlBulkCopy又将如何

[HttpPost]
public async Task<IActionResult> GenerateAndInsertWithSqlBulkCopy([FromQuery] int count = 1000)
{var s = new Stopwatch();s.Start();var users = GenerateUseres(count);var gererationTime = s.Elapsed.ToString();s.Restart();var dt = new DataTable();dt.Columns.Add("Id");dt.Columns.Add("Name");dt.Columns.Add("Birth");dt.Columns.Add("Phone");dt.Columns.Add("Email");foreach (var user in users){dt.Rows.Add(string.Empty, user.Name, user.Birth, user.Phone, user.Email);}using var sqlBulk = new SqlBulkCopy(@"Server=.;Database=EFCore;Trusted_Connection=True;"){DestinationTableName = "Users"};await sqlBulk.WriteToServerAsync(dt);return Ok(new{inserted = dt.Rows.Count,generationTime = gererationTime,insertTime = s.Elapsed.ToString()});
}

因如上利用EF Core新增时间在毫秒级,那么我们则直接从新增1万条开始测试,如下我们可看到此时与EF Core新增1万条数据差异,耗时远远小于1秒

最后我们再来测试10万条,很显然EF Core耗时结果将为SqlBulkCopy的指数倍(大致14倍,若数据为100万,想想二者其性能差异),如下:

若继续通过SQL Server Profiler监控工具查看SQL语句,很显然SQL语句会很简短,据我所知,SqlBulkCopy是直接将数据通过流形式传输到数据库服务器,然后一次性插入到目标表中,所以性能是杠杠的。

利用SqlBulkCopy和EF Core 5.0,当然理论上不论是EF Core更新到其他任何版本,其性能与SqlBulkCopy不可同日而语,本文我们只是稍加探讨下数据量达到多少时不得不考虑其他手段来处理,而不是利用EF Core新增数据

????  EF Core和SqlBulkCopy性能差异比较,毫无疑问SqlBulkCopy为最佳选手

???? 当新增数据量达到1万+时,若需考虑性能,可采用SqlBulkCopy或其他手段处理数据而不再是EF Core,二者性能差异将呈指数增长

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

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

相关文章

小心使用 Task.Run 续篇

关于前两天发布的文章&#xff1a;为什么要小心使用 Task.Run&#xff0c;对文中演示的示例到底会不会导致内存泄露&#xff0c;给很多人带来了疑惑。这点我必须向大家道歉&#xff0c;是我对导致内存泄漏的原因没描述和解释清楚&#xff0c;也没用实际的示例证实&#xff0c;是…

java实用教程——组件及事件处理——设置组件的位置(相对于窗口具体位置和布局)

1&#xff1a; 相对于窗口的具体位置 关键点&#xff1a; JButton组件添加到JPanel时&#xff0c;如果想自己位置&#xff0c;需要对JPanel进行如下设置&#xff0c;才能自定义按钮位置 需要将组件添加到画板上去&#xff0c;才可以设置组件的相对具体位置 button1.setBounds…

usb接口定义引脚说明_PerfDogService使用说明

令牌申请教程&#xff1a;https://bbs.perfdog.qq.com/article-detail.html?id55安装包下载&#xff1a;https://perfdog.qq.com/sdk一、 概述PerfDog性能狗服务组件&#xff0c;用户可基于service组件二次开发自己PerfDog性能工具或自动化服务。本文档主要对PerfDogService提…

java实用教程——组件及事件处理——布局管理(五种)

1.流式布局FlowLayout public void pack()调整此窗口的大小&#xff0c;以适合其子组件的首选大小和布局。如果该窗口或其所有者仍不可显示&#xff0c;则两者在计算首选大小之前变得可显示。在计算首选大小之后&#xff0c;将会验证该Window。窗口自动适应大小&#xff0c;使…

个人博客前端模板_腾讯前端开发工程师,教你极速搭建一个个人博客网站

作者&#xff1a; bookerzhao&#xff0c;腾讯 CSIG web前端开发工程师Github 为开源项目提供了用于静态页面展示的 Pages 服务&#xff0c;很多开发者都在上面托管了自己的静态网站和博客&#xff0c;不少开源项目的案例和文档页面也采用了这种方式。不过由于 Pages 的 CDN 节…

云原生时代 给予.NET的机会

.NET诞生于与Java的竞争&#xff0c;微软当年被罚款20亿美元。Java绝不仅仅是一种语言&#xff0c;它是COM的替代者&#xff01;而COM恰恰是Windows的编程模型。而Java编程很多时候比C编程要容易的多&#xff0c;更致命的是他是跨平台的。微软所推行.NET战略&#xff0c;并且C#…

java实用教程——组件及事件处理——布局的一个小实例

import javax.swing.*; import java.awt.*;public class BasicComponentDemo {Frame frame new Frame("这里测试基本组件");//定义一个按钮Button ok new Button("确认");//定义一个复选框组CheckboxGroup cbg new CheckboxGroup();//定义一个单选框&am…

非极大值抑制_非极大值抑制(non-maximum suppression)

摘自https://blog.csdn.net/qq_38906523/article/details/80195119摘自https://blog.csdn.net/xiexu911/article/details/80609298非极大值抑制NMS在目标检测&#xff0c;定位等领域是一种被广泛使用的方法。对于目标具体位置定位过程&#xff0c;不管是使用sliding Window还是…

TIOBE12月榜单:Java重回第二,Python有望四连冠年度语言

喜欢就关注我们吧&#xff01;文|白开水TIOBE 公布了 2020 年 12 月的编程语言排行榜。TIOBE 将在下个月公布 2020 年的年度编程语言&#xff0c;一年内排名率增长最高的编程语言将获得这一称号。目前&#xff0c;Python 以 1.90% 数据遥遥领先。其次分别是 C&#xff08;0.71%…

excel怎么在柱状图上加超链_如何让你的年终总结更符合领导心意,高薪员工必备的excel技能...

临近年底了&#xff0c;好多人都在写年终总结了&#xff0c;惯有的模式就是写一写这一年都做了哪些工作&#xff0c;有什么成绩&#xff0c;未来将如何完善等等......但是如何反应自己一年以来的成绩呢&#xff0c;如果单单是以文字的形式表述怕是不能让领导满意&#xff0c;甚…

java实用教程——组件及事件处理——对话框(dialog)

对话框&#xff1a; import java.awt.event.ActionEvent;import java.awt.event.ActionListener; import java.awt.*; import java.awt.event.*;public class DialogDemo1 {public static void main(String[] args) {Frame frame new Frame("这里测试Dialog");Di…

Vue 凭什么成为 2020 年的一匹黑马

Vue 在前端开发中的火爆程度远超 React 和 Angular &#xff0c;无论是 BAT 等大厂&#xff0c;还是小型初创公司&#xff0c;Vue 都有着广泛的应用&#xff0c;其相关技术原理也是面试的必考知识点。Vue 的优势太过明显&#xff1a;基于 HTML 的模板语法&#xff0c;响应式的更…

python——学习笔记1

推荐阅读&#xff1a; 爆肝十二万字《python从零到精通教程》 Python菜鸟教程 1.python 的输入输出&#xff1a; 输入&#xff1a;input() 输出&#xff1a;print() 输出不换行&#xff1a;print(x,end"") 数据要和字符串同时输出的时候需要将数据转化为字符串类…

开源C# Winform控件库《SunnyUI》强力推荐

本站(https://dotnet9.com)曾介绍过一款Winform开源控件库《HZHControls》&#xff0c;文章发布后不少朋友热情的咨询相关控件库信息&#xff0c;由此看来Winform在大家心中的地位还是挺高的。今天小编再分享一款新鲜出炉的 Winform 控件库库——SunnyUI&#xff0c;一起跟 Dot…

python——学习笔记2

python的数据结构 字符串&#xff1a; 字符串小写转大写&#xff1a; 字符串大写转小写&#xff1a; 删除空格&#xff1a; 空白是实际文本之前和/或之后的空间&#xff0c;通常您想删除这个空间。 strip()方法从开头或结尾删除任何空格&#xff1a; 替换字符串: replace()方…

庐山真面目之一 微服务的简介和技术栈

一、简介 这些年软件的设计规模越来越庞大&#xff0c;业务需求也越来越复杂&#xff0c;针对系统的性能、高吞吐率、高稳定性、高扩展等特性提出了更高的要求。可以说业务需求是软件架构能力的第一推动力&#xff0c;由于这些因素导致了软件架构思想和相关技术也在发生…

.net 读蓝牙数据_Linux内核曝严重蓝牙漏洞,影响多个版本

谷歌安全研究人员在Linux Kernel中发现了一组蓝牙漏洞(BleedingTooth)&#xff0c;该漏洞可能允许攻击者进行零点击攻击&#xff0c;运行任意代码或访问敏感信息。BleedingTooth漏洞分别被命名为CVE-2020-12351&#xff0c;CVE-2020-12352和CVE-2020-24490。其中最严重的漏洞是…

python——学习笔记3

日期&#xff1a; Python 日期和时间 函数&#xff1a; python 传不可变对象实例

算法题目——电梯(HDU-1008)

题目链接&#xff1a;HDU-1008 上楼&#xff1a;输入俩楼层之差 * 6s 停留层的5s 下楼&#xff1a;输入俩楼层之差 * 4s 停留层的5s #include<iostream> #include<vector>using namespace std; int main() {vector<int> vec;//用于存储每次的楼层数 vector…

.NET 云原生架构师训练营(模块二 基础巩固 引入)--学习笔记

2.1 引入http协议web server && web application framework.net 与 .net core asp .net coreweb api 示例CS&#xff1a;客户端-服务器BS&#xff1a;浏览器-服务器2.1.1 http协议请求过程消息结构请求方法状态码header请求过程1.URL解析2.DNS查询3.TCP连接4.处理请求5…