等待很长时间从数据库中获取数据

时间:2016-08-25 06:41:44

标签: c# c#-4.0

虽然获取数据似乎很长一段时间,但在此期间我们无法完成另一项任务。我正在使用BAckGroundWOrker来达到这个目的。但是在获取所有数据之后似乎等了很长时间才能运行应用程序

  private void btnExrtPDF_Click(object sender, RoutedEventArgs e)
     {
         btnExrtPDF.IsEnabled = false;
         Collection.Clear();                

         long NoOfRecords = 10000;
         long RecordsIcrease = 10000;
         SaveFileDialog xsfd = new SaveFileDialog()
         {
             FileName = "Book1",
             DefaultExt = ".xlsx",
             Filter = "Excel Document|*.xlsx",
             InitialDirectory = new System.IO.DirectoryInfo(Environment.GetFolderPath(Environment.SpecialFolder.Desktop)).ToString()
         };
         Nullable<bool> result = xsfd.ShowDialog();
         System.Data.DataTable batchFCSB = new System.Data.DataTable();
         int row = 0;
         if (result == true)
         {

             DetailReportFCBuySell = AlyexWCFService.DL.DLTTIn.FCBuySELL(transactionName, isDetails, Convert.ToDateTime(dateEdtStartDate.EditValue).Date, Convert.ToDateTime(dtpEditEndDate.EditValue).Date, Customerid, ProductID, branchID, NoOfRecords, PageIndex - 1, isBuy);
             batchFCSB = DetailReportFCBuySell.ToDataTable();
             Collection.Add(row, batchFCSB);
             row = 1;
             PageIndex++;

             for (long k = NoOfRecords; k < DetailReportFCBuySell.FirstOrDefault().TotalRecords; k = +NoOfRecords)
             {

                     new AlxServiceClient().Using(channel =>
                     {
                         DetailReportFCBuySell = new ObservableCollection<DLReports.FCBuySellDetail>();
                         DetailReportFCBuySell = AlyexWCFService.DL.DLTTIn.FCBuySELL(transactionName, isDetails, Convert.ToDateTime(dateEdtStartDate.EditValue).Date, Convert.ToDateTime(dtpEditEndDate.EditValue).Date, Customerid, ProductID, branchID, NoOfRecords, PageIndex - 1, isBuy);
                         batchFCSB = new System.Data.DataTable();
                         batchFCSB = DetailReportFCBuySell.ToDataTable();
                         Collection.Add(row, batchFCSB);
                         row++;   

                 });
                 NoOfRecords = NoOfRecords + RecordsIcrease;
             }


             for (int k = 0; k < Collection.Keys.Count; k++)
             {
                 string xlsxFile = string.Empty;
                 xlsxFile = System.IO.Path.GetTempFileName();                    

                 TableView temp = new TableView();
                 temp.DataContext = (Collection.Where(i => i.Key == k).FirstOrDefault().Value);
                // ExportToXlsx(temp, xlsxFile);
             }
            }
m_oWorker.RunWorkerAsync();
}

2 个答案:

答案 0 :(得分:1)

我将editvalue设为一个单独的对象并在线程中调用该对象

DateTime startDate =    Convert.ToDateTime(dateEdtStartDate.EditValue).Date;
DateTime endDate = Convert.ToDateTime(dtpEditEndDate.EditValue).Date;

private DetailReportFCBuySell FetchRecord ()
{
return ObservableCollection<DLReports.FCBuySellDetail> temp = AlyexWCFService.DL.DLTTIn.FCBuySELL(transactionName, isDetails, startDate, endDate, Customerid, ProductID, branchID, NoOfRecords, PageIndex - 1, isBuy);
}

答案 1 :(得分:0)

代码块似乎从点击事件的开始运行而不调用BGWorker,考虑将代码块移动到单个函数中,如

private DetailReportFCBuySell FetchRecord ()
{
    return AlyexWCFService.DL.DLTTIn.FCBuySELL(transactionName, isDetails, Convert.ToDateTime(dateEdtStartDate.EditValue).Date, Convert.ToDateTime(dtpEditEndDate.EditValue).Date, Customerid, ProductID, branchID, NoOfRecords, PageIndex - 1, isBuy);
}

并在m_oWorker Do Work事件中调用此函数

private void bw_DoWork(object sender, DoWorkEventArgs e)
{
    FetchRecord();
}

详情请阅读https://msdn.microsoft.com/en-us/library/cc221403(v=vs.95).aspx#code-snippet-3