欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# Oracle批量插入數(shù)據(jù)進度條的實現(xiàn)代碼

 更新時間:2018年04月04日 16:21:13   作者:heyyw  
這篇文章主要介紹了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ù)庫中相應(yīng)表格的字段完全對應(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ù)庫連接對象
  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ù)庫中。為了利用進度條控件實現(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)設(shè)置最大值為100,最小值為0
}

經(jīng)過改進后以上代碼即可讓用戶實時看到數(shù)據(jù)插入進度,雖然在一定程度上會影響插入的效率,但換來了用戶對插入狀態(tài)的了解,而且這種影響在數(shù)據(jù)量不是特別巨大的情況下幾乎可以忽略。

總結(jié)

以上所述是小編給大家介紹的C# Oracle批量插入數(shù)據(jù)進度條的實現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • C# TSC打印二維碼和條形碼的實現(xiàn)方法

    C# TSC打印二維碼和條形碼的實現(xiàn)方法

    下面小編就為大家分享一篇C# TSC打印二維碼和條形碼的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • C# yield關(guān)鍵字詳解

    C# yield關(guān)鍵字詳解

    這篇文章主要介紹了C# yield關(guān)鍵字詳解,本文講解了yield是一個語法糖、語法糖的實現(xiàn)(實現(xiàn)IEnumerable<T>接口的類)、yield使用中的特殊情況等內(nèi)容,需要的朋友可以參考下
    2015-04-04
  • Unity實現(xiàn)物體沿自身的任意軸向旋轉(zhuǎn)

    Unity實現(xiàn)物體沿自身的任意軸向旋轉(zhuǎn)

    這篇文章主要為大家詳細介紹了Unity實現(xiàn)物體沿自身的任意軸向旋轉(zhuǎn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • C#自定義函數(shù)NetxtString生成隨機字符串

    C#自定義函數(shù)NetxtString生成隨機字符串

    這篇文章主要介紹了C#自定義函數(shù)NetxtString生成隨機字符串,是十分常見的重要功能,需要的朋友可以參考下
    2014-08-08
  • C#編寫SqlHelper類

    C#編寫SqlHelper類

    在C#中使用ADO.NET連接數(shù)據(jù)庫的時候,每次連接都要編寫連接,打開,執(zhí)行SQL語句的代碼,很麻煩,編寫一個SqlHelper類,把每次連接都要寫的代碼封裝成方法,把要執(zhí)行的SQL語句通過參數(shù)傳進去,可以大大簡化編碼
    2017-09-09
  • C#獲取路由器外網(wǎng)IP,MAC地址的實現(xiàn)代碼

    C#獲取路由器外網(wǎng)IP,MAC地址的實現(xiàn)代碼

    這篇文章主要介紹了C#獲取路由器外網(wǎng)IP,MAC地址的實現(xiàn)代碼,需要的朋友可以參考下
    2016-11-11
  • C# winform打開Excel文檔的方法總結(jié)(必看篇)

    C# winform打開Excel文檔的方法總結(jié)(必看篇)

    下面小編就為大家?guī)硪黄狢# winform打開Excel文檔的方法總結(jié)(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • C# 6.0 內(nèi)插字符串(Interpolated Strings )的使用方法

    C# 6.0 內(nèi)插字符串(Interpolated Strings )的使用方法

    這篇文章主要為大家詳細介紹了C# 6.0 內(nèi)插字符串的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • C#集合之列表的用法

    C#集合之列表的用法

    這篇文章介紹了C#集合之列表的用法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • asp.net中調(diào)用oracle存儲過程的方法

    asp.net中調(diào)用oracle存儲過程的方法

    存儲過程是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL 語句集,存儲在數(shù)據(jù)庫中經(jīng)過第一次編譯后再次調(diào)用不需要再次編譯,用戶通過指定存儲過程的名字并給出參數(shù)來執(zhí)行它,下面給大家介紹下asp.net中調(diào)用oracle存儲過程的方法,需要的朋友可以參考下
    2015-08-08

最新評論