当前位置:
首页 > Python基础教程 >
-
C#教程之C# Oracle批量插入数据进度条制作
前言
由于项目需求,需要将Excel中的数据进过一定转换导入仅Oracle数据库中。考虑到当Excel数据量较大时,循环Insert语句效率太低,故采用批量插入的方法。在插入操作运行时,会造成系统短暂的“卡死”现象。为了让用户知道插入的状态,需要制作一个进度条来显示插入的进度。
批量插入
项目中运用的是System.Data.OracleClient。首先将Excel数据通过转换函数转换为DataTable,其中的字段和数据库中相应表格的字段完全对应。
public int Import2Oracle(ISheet sheet, string tablename)
{
DataTable dt = GetDataFromExcelByNPOI(sheet); //经过转换后获得DataTable
OracleCommand cmd = conn.CreateCommand();// conn为数据库连接对象
OracleDataAdapter da = new OracleDataAdapter(cmd);
OracleCommandBuilder ocb = new OracleCommandBuilder(da);
string SelectSQL = "select * from "+tablename+ " where ROWNUM=0";
da.SelectCommand.CommandText = SelectSQL;
da.InsertCommand = ocb.GetInsertCommand();
da.Update(dt);
return 1; //返回正常
}
上述代码没有列出连接Oracle数据库相关代码,该段代码将DataTable批量插入数据库中。为了利用进度条控件实现显示插入的进度,需要在每次成功插入一条数据后更新进度条。
进度条实现
为了实现实时更新插入进度,需要用到OracleDataAdapter类下RowUpdated事件。官方文档中有注释,当使用Update方法时,在每一条记录更新时会发生两个事件,即OnRowUpdating和OnRowUpdated。利用OnRowUpdated这个事件即可记录已插入多少条数据,显示插入进度。
int Sum = 0; //总记录数
int rowNum = 0; //插入记录数
public int Import2Oracle(ISheet sheet)
{
Sum = sheet.LastRowNum - 1; //获取总记录数
DataTable dt = GetDataFromExcelByNPOI(sheet); //经过转换后获得DataTable,利用到了NPOI
OracleCommand cmd = conn.CreateCommand();// conn为数据库连接对象
OracleDataAdapter da = new OracleDataAdapter(cmd);
OracleCommandBuilder ocb = new OracleCommandBuilder(da);
string SelectSQL = "select * from GZGDZL."+tablename+ " where ROWNUM=0";
da.SelectCommand.CommandText = SelectSQL;
da.InsertCommand = ocb.GetInsertCommand();
// update, this operation fires two events
// (RowUpdating/RowUpdated) per changed row
//这里只用到RowUpdated事件
da.RowUpdated += new OracleRowUpdatedEventHandler(OnRowUpdated);
da.Update(dt);
return 1; //返回正常
}
//OnRowUpdated事件
private void OnRowUpdated(object sender, OracleRowUpdatedEventArgs e)
{
//刷新界面进度条
rowNum = rowNum + 1;
reportValue = (int)(rowNum /m_sheet.LastRowNum * 100);
this.progressBar1.Value = percent; //progressBar控件已经设置最大值为100,最小值为0
}
经过改进后以上代码即可让用户实时看到数据插入进度,虽然在一定程度上会影响插入的效率,但换来了用户对插入状态的了解,而且这种影响在数据量不是特别巨大的情况下几乎可以忽略。
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式