EF结合SqlBulkCopy实现高效的批量数据插入 |EF插件EntityFramework.Extended实现批量更新和删除
原文链接:http://blog.csdn.net/fanbin168/article/details/51485969
批量插入 (17597条数据批量插入耗时1.7秒)
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using System.Web.Mvc;
- namespace MvcApplication1.Controllers
- {
- using MvcApplication1.Models;
- using EntityFramework.Extensions;
- using System.ComponentModel;
- using System.Data;
- using System.Data.SqlClient;
- using System.Diagnostics;
- public class HomeController : Controller
- {
- public ActionResult Index()
- {
- Stopwatch sw = new Stopwatch(); //计时器
- sw.Start();//开始计时
- using (var db = new salesEntities())
- {
- List<location> entitys = db.location.ToList(); //构建集合,到时候会将这个集合数据批量插入到
- if (db.Database.Connection.State != ConnectionState.Open)
- {
- db.Database.Connection.Open(); //打开Connection连接
- }
- //调用BulkInsert方法,将entitys集合数据批量插入到数据库的tolocation表中
- BulkInsert<location>((SqlConnection)db.Database.Connection, "tolocation", entitys);
- if (db.Database.Connection.State != ConnectionState.Closed)
- {
- db.Database.Connection.Close(); //关闭Connection连接
- }
- }
- sw.Stop(); //结束计时
- string aa = sw.Elapsed.ToString();//批量插入了17597条数据。耗时1.7秒
- return View();
- }
- /// <summary>
- /// 批量插入
- /// </summary>
- /// <typeparam name="T">泛型集合的类型</typeparam>
- /// <param name="conn">连接对象</param>
- /// <param name="tableName">将泛型集合插入到本地数据库表的表名</param>
- /// <param name="list">要插入大泛型集合</param>
- public static void BulkInsert<T>(SqlConnection conn, string tableName, IList<T> list)
- {
- using (var bulkCopy = new SqlBulkCopy(conn))
- {
- bulkCopy.BatchSize = list.Count;
- bulkCopy.DestinationTableName = tableName;
- var table = new DataTable();
- var props = TypeDescriptor.GetProperties(typeof(T))
- .Cast<PropertyDescriptor>()
- .Where(propertyInfo => propertyInfo.PropertyType.Namespace.Equals("System"))
- .ToArray();
- foreach (var propertyInfo in props)
- {
- bulkCopy.ColumnMappings.Add(propertyInfo.Name, propertyInfo.Name);
- table.Columns.Add(propertyInfo.Name, Nullable.GetUnderlyingType(propertyInfo.PropertyType) ?? propertyInfo.PropertyType);
- }
- var values = new object[props.Length];
- foreach (var item in list)
- {
- for (var i = 0; i < values.Length; i++)
- {
- values[i] = props[i].GetValue(item);
- }
- table.Rows.Add(values);
- }
- bulkCopy.WriteToServer(table);
- }
- }
- }
- }
使用EF扩展EntityFramework.Extended 对数据进行批量更新,和批量删除
批量更新(17597条数据,批量更新耗时1.69秒)
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using System.Web.Mvc;
- namespace MvcApplication1.Controllers
- {
- using MvcApplication1.Models;
- using EntityFramework.Extensions; //使用EF的EntityFramework.Extended插件需要引入此名称空间
- using System.Diagnostics;
- public class HomeController : Controller
- {
- public ActionResult Index()
- {
- salesEntities db = new salesEntities();
- Stopwatch sw = new Stopwatch(); //计时器
- sw.Start();
- //调用插件的Update方法进行批量更新(不需要我们手动的db.SaveChanges()了)
- //db.location.Update(r => new location { version = 123 });//批量将location表里version字段数据更新为123
- db.tolocation.Where(r => r.locId < 100).Update(c => new tolocation { version = 236 }); //也可以带条件批量修改
- sw.Stop();
- string aa = sw.Elapsed.ToString();//批量更新了17597条数据。耗时1.69秒
- return View();
- }
- }
- }
批量删除(17597条数据,批量删除耗时1.76秒)
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using System.Web.Mvc;
- namespace MvcApplication1.Controllers
- {
- using MvcApplication1.Models;
- using EntityFramework.Extensions; //使用EF的EntityFramework.Extended插件需要引入此名称空间
- using System.Diagnostics;
- public class HomeController : Controller
- {
- public ActionResult Index()
- {
- salesEntities db = new salesEntities();
- Stopwatch sw = new Stopwatch(); //计时器
- sw.Start();
- //调用插件的Delete方法进行批量删除(不需要我们手动的db.SaveChanges()了)
- //db.location.Delete(r => r.locId < 100000);
- db.location.Where(r => r.locId < 10000).Delete(); //当然我也可以这样写
- sw.Stop();
- string aa = sw.Elapsed.ToString();//批量删除了17597条数据。耗时1.76秒
- return View();
- }
- }
- }
EF结合SqlBulkCopy实现高效的批量数据插入 |EF插件EntityFramework.Extended实现批量更新和删除的更多相关文章
- yii批量数据插入
yii框架批量插入数据有两种方法,第一种是循环多次插入和一次批量插入,第一种方法要注意插入数据中间有一次数据插入失败要注意回滚事务 循环插入数据 第一种方法 $model = new User(); ...
- MyBatis Plus 批量数据插入功能,yyds!
最近 Review 小伙伴代码的时候,发现了一个小小的问题,小伙伴竟然在 for 循环中进行了 insert (插入)数据库的操作,这就会导致每次循环时都会进行连接.插入.断开连接的操作,从而导致一定 ...
- ef和mysql使用(二)--让mysql支持EntityFramework.Extended实现批量更新和删除
我们都知道Entity Framework 中不能同时更新多条记录,但是一个老外写的扩展库可以实现此功能EntityFramework.Extended,但是如何是mysql数据库要怎么实现呢 首先实 ...
- 使用SqlBulkCopy进行批量数据插入
Dim dt As DataTable = New DataTable() dt.Columns.Add("DtCostProductRuleGUID", GetType(Guid ...
- 原创 SqlParameter 事务 批量数据插入
不错,很好,以后防注入批量事务提交虽然麻烦点研究了几个小时,但不会是问题了 SqlCommand cmd; HelpSqlServer helps = new HelpSqlServer(); //定 ...
- [oracle/java/sql]用于上十万批量数据插入Oracle表的Java程序
程序下载:https://files.cnblogs.com/files/xiandedanteng/LeftInnerNotExist20191222.rar 原理:Oracle的Insert al ...
- KingbaseES批量数据加载的实践技巧
有时,KingbaseES数据库需要在单个或最少的步骤中导入大量数据,这通常称为批量数据导入.其中数据源通常是一个或多个大文件,这个过程有时可能非常慢. 造成性能不佳的原因有很多:索引.触发器.外键. ...
- EntityFramework 插件之EntityFramework.Extended (批量处理)
接手了一个用EF来做的项目,由于项目中使用的原生处理,导致很多update都是采用先select 后 update的方式来实现,同时无法批量执行逻辑如:根据订单类型统一更新状态等.所以在经过了N多查找 ...
- 15.更新和删除数据--SQL
一.更新数据 更新(修改)表中的数据,可以使用UPDA TE语句.有两种使用UPDA TE的方式: 更新表中的特定行: 更新表中的所有行. 警告:不要省略WHERE子句 在使用UPDA TE时一定要细 ...
随机推荐
- Esri大数据分析引擎GeoAnalytics Server部署经历
系统架构 Base WebGIS 4Cores 16GB Spatiotemporal Data Store 32GB SSD Disk 足够大的空间 GA Server 4Cores 16GB 足够 ...
- 仿小米便签图文混排 EditText解决尾部插入文字bug
一直想实现像小米便签那样的图文混排效果,收集网上的办法无非三种: 1.自定义布局,每张图片是一个ImageView,插入图片后插入EditText,缺点是实现复杂,不能像小米便签那样同时选中图片和文字 ...
- centos虚拟机网卡配置
连接模式为NAT
- c# 设计模式 之:工厂模式之---工厂模式
1.uml类图: 实现和依赖关系: 实现: SportFactory.JeepFactory.HatchbackFactory 实现 IFactory 接口 SportCar.JeepCar.Hatc ...
- NodeJS的特点
一. NodeJS的特点 我们先来看看NodeJS官网上的介绍: Node.js is a platform built on Chrome’s JavaScript runtime for easi ...
- 使用iCarousel的旋转木马效果请求图片
使用iCarousel的旋转木马效果请求图片 https://github.com/nicklockwood/iCarousel 先看看效果: 源码如下: // // RootViewControll ...
- iOS设计模式 - 适配器
iOS设计模式 - 适配器 效果 说明 1. 为了让客户端尽可能的通用,我们使用适配器模式来隔离客户端与外部参数的联系,只让客户端与适配器通信. 2. 本教程实现了适配器模式的类适配器与对象适配器两种 ...
- Axure RP 8 V1.6 授权码
原文链接:https://blog.csdn.net/love_xiaozhao/article/details/81085500 可使用的: Axure RP 8.1.0.3377—-亲测可用Lic ...
- 在 Windows Server Container 中运行 Azure Storage Emulator(一):能否监听自定义地址?
我要做什么? 改 ASE 的监听地址.对于有强迫症的我来说,ASE 默认监听的是 127.0.0.1:10000-10002,这让我无法接受,所以我要将它改成域名 + 80 端口的方式: 放到容器中. ...
- Asp.Net MVC Identity 2.2.1 使用技巧(二)
之前我们看到了新生成的项目中跟identity有关的有四个文件,这些文件是基础功能,并未开启identity的全部功能.现在我们先启用角色功能. 1.在App_Start文件夹中的IdentityCo ...