C# Oracle批量插入數(shù)據(jù)進度條的實現(xiàn)代碼
前言
由于項目需求,需要將Excel中的數(shù)據(jù)進過一定轉(zhuǎn)換導入僅Oracle數(shù)據(jù)庫中??紤]到當Excel數(shù)據(jù)量較大時,循環(huán)Insert語句效率太低,故采用批量插入的方法。在插入操作運行時,會造成系統(tǒng)短暫的“卡死”現(xiàn)象。為了讓用戶知道插入的狀態(tài),需要制作一個進度條來顯示插入的進度。
批量插入
項目中運用的是System.Data.OracleClient
。首先將Excel數(shù)據(jù)通過轉(zhuǎn)換函數(shù)轉(zhuǎn)換為DataTable,其中的字段和數(shù)據(jù)庫中相應表格的字段完全對應。
public int Import2Oracle(ISheet sheet, string tablename) { DataTable dt = GetDataFromExcelByNPOI(sheet); //經(jīng)過轉(zhuǎn)換后獲得DataTable OracleCommand cmd = conn.CreateCommand();// conn為數(shù)據(jù)庫連接對象 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數(shù)據(jù)庫相關代碼,該段代碼將DataTable批量插入數(shù)據(jù)庫中。為了利用進度條控件實現(xiàn)顯示插入的進度,需要在每次成功插入一條數(shù)據(jù)后更新進度條。
進度條實現(xiàn)
為了實現(xiàn)實時更新插入進度,需要用到OracleDataAdapter類下RowUpdated事件。官方文檔中有注釋,當使用Update方法時,在每一條記錄更新時會發(fā)生兩個事件,即OnRowUpdating和OnRowUpdated。利用OnRowUpdated這個事件即可記錄已插入多少條數(shù)據(jù),顯示插入進度。
int Sum = 0; //總記錄數(shù) int rowNum = 0; //插入記錄數(shù) public int Import2Oracle(ISheet sheet) { Sum = sheet.LastRowNum - 1; //獲取總記錄數(shù) DataTable dt = GetDataFromExcelByNPOI(sheet); //經(jīng)過轉(zhuǎn)換后獲得DataTable,利用到了NPOI OracleCommand cmd = conn.CreateCommand();// conn為數(shù)據(jù)庫連接對象 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控件已經(jīng)設置最大值為100,最小值為0 }
經(jīng)過改進后以上代碼即可讓用戶實時看到數(shù)據(jù)插入進度,雖然在一定程度上會影響插入的效率,但換來了用戶對插入狀態(tài)的了解,而且這種影響在數(shù)據(jù)量不是特別巨大的情況下幾乎可以忽略。
總結(jié)
以上所述是小編給大家介紹的C# Oracle批量插入數(shù)據(jù)進度條的實現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對我們網(wǎng)站的支持!
欄 目:C#教程
本文標題:C# Oracle批量插入數(shù)據(jù)進度條的實現(xiàn)代碼
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5208.html
您可能感興趣的文章
- 01-10C#.NET中如何批量插入大量數(shù)據(jù)到數(shù)據(jù)庫中
- 01-10C#實現(xiàn)SQL批量插入數(shù)據(jù)到表的方法
- 01-10mvc C# JavaScript LigerUI oracle實現(xiàn)用戶的注冊、登陸驗證、登陸
- 01-10C#下listview如何插入圖片
- 01-10C#實現(xiàn)winform中RichTextBox在指定光標位置插入圖片的方法
- 01-10C#操作SQLite數(shù)據(jù)庫方法小結(jié)(創(chuàng)建,連接,插入,查詢,刪除等)
- 01-10C#向Word插入排版精良的TextBox
- 01-10C#中創(chuàng)建PDF網(wǎng)格并插入圖片的方法
- 01-10c#幾種數(shù)據(jù)庫的大數(shù)據(jù)批量插入(SqlServer、Oracle、SQLite和MySql)
- 01-10詳解C#批量插入數(shù)據(jù)到Sqlserver中的四種方式


閱讀排行
本欄相關
- 01-10C#通過反射獲取當前工程中所有窗體并
- 01-10關于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當前操作系統(tǒng)已
隨機閱讀
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10C#中split用法實例總結(jié)
- 04-02jquery與jsp,用jquery