国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C# Oracle批量插入數據進度條的實現代碼

2019-10-29 21:06:10
字體:
來源:轉載
供稿:網友

前言

由于項目需求,需要將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批量插入數據進度條的實現代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 徐闻县| 临夏市| 武冈市| 栾川县| 建昌县| 泽州县| 泽库县| 永福县| 余江县| 唐海县| 辽阳市| 布尔津县| 德阳市| 海城市| 鄂托克前旗| 金华市| 景宁| 乌苏市| 嘉荫县| 安福县| 永宁县| 永宁县| 南和县| 萨迦县| 资源县| 华亭县| 中牟县| 普安县| 眉山市| 澄江县| 长葛市| 合山市| 保靖县| 昭觉县| 灵寿县| 竹溪县| 江北区| 东阿县| 台州市| 白银市| 公安县|