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


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻 器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 01-10C#中split用法實(shí)例總結(jié)
- 04-02jquery與jsp,用jquery