C# Oracle批量插入數據進度條製做

前言

因爲項目需求,須要將Excel中的數據進過必定轉換導入僅Oracle數據庫中。考慮到當Excel數據量較大時,循環Insert語句效率過低,故採用批量插入的方法。在插入操做運行時,會形成系統短暫的「卡死」現象。爲了讓用戶知道插入的狀態,須要製做一個進度條來顯示插入的進度。數據庫

批量插入

項目中運用的是System.Data.OracleClient。首先將Excel數據經過轉換函數轉換爲DataTable,其中的字段和數據庫中相應表格的字段徹底對應。oracle

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這個事件便可記錄已插入多少條數據,顯示插入進度。ui

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
}

通過改進後以上代碼便可讓用戶實時看到數據插入進度,雖然在必定程度上會影響插入的效率,但換來了用戶對插入狀態的瞭解,並且這種影響在數據量不是特別巨大的狀況下幾乎能夠忽略。this

相關文章
相關標籤/搜索