C# Oracle批量插入数据进度条的实现代码

 更新时间:2018年04月04日 16:21:13   作者:heyyw  
这篇文章主要介绍了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
}

经过改进后以上代码即可让用户实时看到数据插入进度,虽然在一定程度上会影响插入的效率,但换来了用户对插入状态的了解,而且这种影响在数据量不是特别巨大的情况下几乎可以忽略。

总结

以上所述是小编给大家介绍的C# Oracle批量插入数据进度条的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • C# SQLite事务操作方法分析

    C# SQLite事务操作方法分析

    这篇文章主要介绍了C# SQLite事务操作方法,简单分析了使用SQL代码及C#代码实现事务功能的操作技巧,需要的朋友可以参考下
    2017-07-07
  • C#中ManualResetEvent用法总结

    C#中ManualResetEvent用法总结

    这篇文章主要介绍了C#中ManualResetEvent用法总结,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下
    2021-01-01
  • c#中使用自动属性减少代码输入量

    c#中使用自动属性减少代码输入量

    .Net 3.0中的自动属性可以大幅度降低我们输入的代码量,需要的朋友可以参考下
    2012-12-12
  • C# 4.0 大数的运算--BigInteger的应用详解

    C# 4.0 大数的运算--BigInteger的应用详解

    本篇文章是对C# 4.0 大数的运算 BigInteger的应用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C#实现块状链表的项目实践

    C#实现块状链表的项目实践

    这篇文章主要介绍了C#实现块状链表的项目实践,通过定义块和链表类,利用块内元素引用实现块与块之间的链接关系,从而实现对块状链表的遍历、插入和删除等操作,感兴趣的可以了解一下
    2023-11-11
  • .NET垃圾回收器(GC)原理浅析

    .NET垃圾回收器(GC)原理浅析

    这篇文章主要介绍了.NET垃圾回收器(GC)原理浅析,本文先是讲解了一些基础知识如托管堆(Managed Heap)、CPU寄存器(CPU Register)、根(Roots)等,然后讲解了垃圾回收的基本原理、算法等,需要的朋友可以参考下
    2015-01-01
  • C# LiteDB基本使用示例代码

    C# LiteDB基本使用示例代码

    LiteDB是一种文档型单文件数据库,基于Key-Value方式存取数据,LiteDB 的灵感来自 MongoDB 数据库,所以它的 API 和 MongoDB 的 .NET API 非常相似,这篇文章主要介绍了C# LiteDB基本使用,需要的朋友可以参考下
    2024-03-03
  • C#启动和停止windows服务的实例代码

    C#启动和停止windows服务的实例代码

    这篇文章介绍了C#启动和停止windows服务的实例代码,有需要的朋友可以参考一下
    2013-09-09
  • C#利用Refit实现JWT自动续期详解

    C#利用Refit实现JWT自动续期详解

    Refit 是一个受到Square的Retrofit库(Java)启发的自动类型安全REST库,这篇文章主要为大家介绍了C#如何利用Refit实现JWT自动续期,感兴趣的可以了解下
    2023-08-08
  • C#编程总结(六)详解异步编程

    C#编程总结(六)详解异步编程

    本篇文章主要介绍了C#异步编程,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧。
    2016-12-12

最新评论