Vsual Studio 2022 MiniExcel + EF+CodeFirst + Z.EntityFramework.Extensions大批量数据批量插入、更新、删除

本文主要是介绍Vsual Studio 2022 MiniExcel + EF+CodeFirst + Z.EntityFramework.Extensions大批量数据批量插入、更新、删除,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • MiniExcel
  • Z.EntityFramework.Extensions
  • 技术实现
    • .app.config文件配置
    • TEST实体类
    • 数据库与模型连接类MiniExcelDb
    • 批量插入
    • 批量更新
    • 批量删除


MiniExcel

简介
MiniExcel简单、高效避免OOM的.NET处理Excel查、写、填充数据工具。

目前主流框架大多需要将数据全载入到内存方便操作,但这会导致内存消耗问题,MiniExcel 尝试以 Stream 角度写底层算法逻辑,能让原本1000多MB占用降低到几MB,避免内存不够情况。

特点
低内存耗用,避免OOM、频繁 Full GC 情况
支持即时操作每行数据
兼具搭配 LINQ 延迟查询特性,能办到低消耗、快速分页等复杂查询
轻量,不需要安装 Microsoft Office、COM+,DLL小于150KB
简便操作的 API 风格。

开源地址:点击前往

Z.EntityFramework.Extensions

简介
Z.EntityFramework.Extensions,插件收费,EF结合该插件性能很给力,当然网上也有不少破解的,跟破解教程,如果是商用这里还是比较建议购买使用,如果是个人研究学习,在下也觉得还是可以搞一搞的。

获取途径
1.官方网站下载最新的dll文件。
2.VS Nuget直接搜索进行安装。

官方地址:点击前往

技术实现

本例子是基于ADO.NET + CodeFirst + Oracle进行实体建模,如果出现无法选到Oracle驱动就看我另一篇文章Visual Studio 2022 ADO.NET数据实体模型+EF+CodeFirst添加Oracle数据库驱动。还要NuGet安装框架必须支持的EntityFramework6.0、Oracle.ManagedDataAccess、Oracle.ManagedDataAccess.EntityFramework,两个Oracle的要注意版本号一致,因为不是主讲所以这里就直奔主题。

.app.config文件配置

<connectionStrings><!--添加数据库连接--><add name="MiniExcelDb" connectionString="USER ID=xxx;DATA SOURCE=ip/实例;Password=xxx" providerName="Oracle.ManagedDataAccess.Client" />
</connectionStrings>

TEST实体类

namespace MiniExcelImport.Model
{using System;using System.Collections.Generic;using System.ComponentModel.DataAnnotations;using System.ComponentModel.DataAnnotations.Schema;using System.Data.Entity.Spatial;[Table("xxx.TEST")]public partial class TEST{[Key][Column(Order = 0)]public string ID { get; set; }[StringLength(100)]public string CODE{ get; set; }public DateTime? BEGINDATE { get; set; }public DateTime? ENDDATE { get; set; }}
}

数据库与模型连接类MiniExcelDb

using System;
using System.ComponentModel.DataAnnotations.Schema;
using System.Data.Entity;
using System.Linq;namespace MiniExcelImport.Model
{public partial class MiniExcelDb : DbContext{public MiniExcelDb(): base("name=MiniExcelDb"){}public virtual DbSet<TEST> TEST{ get; set; }protected override void OnModelCreating(DbModelBuilder modelBuilder){modelBuilder.Entity<TEST>().Property(e => e.CODE).IsUnicode(false);modelBuilder.Entity<TEST>().Property(e => e.ID).IsUnicode(false);}}
}

批量插入

//关闭大硬盘缓存
var config = new OpenXmlConfiguration { EnableSharedStringCache = false };
//如果Excel中的A列有空的值,则排除这些数据
var rows = MiniExcel.Query(path, configuration: config).TakeWhile(row => row.A != null);
//与数据库建立连接,业务执行完毕会自动释放
using (MiniExcelDb db = new MiniExcelDb())
{//声明表集合对象,用于存放解析到的每一条数据List<TEST> listInset = new List<TEST>();foreach (var row in rows){TEST test = new TEST(){ID = Guid.NewGuid().ToString(),CODE = row.A,BEGINDATE = row.B == null ? null : Convert.ToDateTime(row.B),ENDDATE = row.C == null ? null : Convert.ToDateTime(row.C)};listInset.Add(test);//开始执行插入操作if (listInset.Count > 0){try{db.BulkInsert(listInset);}catch (Exception ex){Console.WriteLine("批量插入失败......");}}}
}

批量更新

与插入的区别就在要找到表中要更改的数据,加到集合中,然后进行批量更新。

//获取哪些数据需要更新
List<TEST> listUpdate = new List<TEST>();
//TEST test = db.TEST.Find(v => v.ID == id);
TEST test = db.TEST.Where(v => v.ID == id).FirstOrDefault();
test.CODE = row.A,
test.BEGINDATE = row.B == null ? null : Convert.ToDateTime(row.B),
test.ENDDATE = row.C == null ? null : Convert.ToDateTime(row.C)
listUpdate.Add(test);
//判断是否有数据
if (listUpdate.Count > 0)
//批量更新
db.BulkUpdate(listUpdate);

批量删除

//获取哪些数据需要删除
List<TEST> listDel= new List<TEST>();
TEST del= new TEST { ID = id};
listDel.Add(del);
//判断是否有数据
if (listDel.Count > 0)
//批量删除
db.BulkDelete(listDel);

MiniExcel还有更深,更高级的用法。开源地址:点击前往

这篇关于Vsual Studio 2022 MiniExcel + EF+CodeFirst + Z.EntityFramework.Extensions大批量数据批量插入、更新、删除的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/201027

相关文章

macOS无效Launchpad图标轻松删除的4 种实用方法

《macOS无效Launchpad图标轻松删除的4种实用方法》mac中不在appstore上下载的应用经常在删除后它的图标还残留在launchpad中,并且长按图标也不会出现删除符号,下面解决这个问... 在 MACOS 上,Launchpad(也就是「启动台」)是一个便捷的 App 启动工具。但有时候,应

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque