中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C#+Oracle如何實現批量插入數據進度條

發布時間:2021-06-30 15:11:09 來源:億速云 閱讀:159 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關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如何實現批量插入數據進度條”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

资兴市| 普宁市| 安泽县| 盱眙县| 晋州市| 台江县| 美姑县| 晋中市| 丰台区| 汉中市| 邵阳县| 渭源县| 平顺县| 汉寿县| 汶川县| 宣化县| 姜堰市| 田林县| 丽江市| 秦皇岛市| 高密市| 哈尔滨市| 湘潭县| 七台河市| 辛集市| 澄迈县| 宁陕县| 铜川市| 杨浦区| 碌曲县| 陈巴尔虎旗| 兰溪市| 平安县| 密山市| 南川市| 龙游县| 徐汇区| 富源县| 庄浪县| 罗田县| 南宁市|