您好,登录后才能下订单哦!
这篇文章给大家分享的是有关C#+Oracle如何实现批量插入数据进度条的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
批量插入
项目中运用的是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如何实现批量插入数据进度条”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。