利用BackgroundWorker 实现线程查询显示进度条,并允许终止查询(模仿SQL查询)

 

 //利用组件实现线程查询
        private SqlCommand fCurCommand;
        private string fCommandText = string.Empty;
        private SqlConnection fConnection;
        private DataSet fdsResult;
        private bool fIsCommandIsCancelOrError = false;

        private delegate void myDelegatDoProcess();
        private delegate void myDelegateSetDataSrc(object t);
        private delegate void PDelegate();
        private delegate void PDelegateA(object t, EventArgs a);

 

            using (BackgroundWorker backgroundWorker = new BackgroundWorker())
            {
                // 异步获取数据
                backgroundWorker.DoWork += new DoWorkEventHandler(delegate(object o, DoWorkEventArgs workerEventArgs)
                {
                    this.BeginInvoke(new myDelegatDoProcess(doProcess )); //利用委托显示进度条

                    fCommandText = strSQL;

                    using (SqlDataAdapter fAdapter = new SqlDataAdapter(fCommandText, fConnection ))
                    {
                        try
                        {
                            fIsCommandIsCancelOrError = false;
                            fCurCommand = fAdapter.SelectCommand;
                            fCurCommand.CommandTimeout = 0;// 永不超时
                            fdsResult = new DataSet();
                            fAdapter.Fill(fdsResult);
                            fCurCommand = null;
                        }
                        catch (Exception x)
                        {
                            //MessageBox.Show(x.Message);
                            fIsCommandIsCancelOrError = true; //查询出错或用户已取消查询
                        }
                    }
                });

                // 数据获取完成,绑定数据
                backgroundWorker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(delegate(object o, RunWorkerCompletedEventArgs x)
                {
                    if (MyGrdQueryResult.IsHandleCreated)
                    {
                        if (!fIsCommandIsCancelOrError)
                        {
                            //this.MyGrdQueryResult.DataSource = fdsResult.Tables[0];
                            bdsQueryResult.DataSource = fdsResult.Tables[0];

                            this.BeginInvoke(new myDelegateSetDataSrc(SetQueryResultData), new object[] { bdsQueryResult });//显示查询结果集

                            this.BeginInvoke(new PDelegate(SetGridViewFrmt));//设置列格式               

                            this.BeginInvoke(new PDelegate(ShowCountRecord));//显示记录总数

                            this.BeginInvoke(new PDelegateA(DoExecSumItem), new object[] { null, null });//执行计算合计         
                        }
                        if (fIsCommandIsCancelOrError == false)
                        {
                            this.tsPressBarQry.Value = 100;
                        }
                    }
                });

                backgroundWorker.RunWorkerAsync();
            }

 

// <summary>
        /// 终止查询
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void tsBtCancel_Click(object sender, EventArgs e)
        {
            if (fCurCommand != null)
            {
                try
                {                   
                    fCurCommand.Cancel();
                    //MessageBox.Show("查询已停止");
                }
                catch (Exception x)
                {
                    MessageBox.Show(x.Message);
                }
            }
            //flagCancel = true;
            //tmyThrdGetdata.Abort();
            //tmyTrrdProcess.Abort();
        }       
  

/// <summary>
        /// 显示进度条
        /// </summary>
        private void doProcess()
        {
            if (tsPressBarQry.IsDisposed == false)
            {
                this.tsPressBarQry.Value = 0;
                tsPressBarQry.Minimum = 0;
                tsPressBarQry.Maximum = 100;
                tsPressBarQry.Step = 10;
                while ((tsPressBarQry.IsDisposed == false) && (tsPressBarQry.Value < 100))
                {
                    //if (flagCancel) { break; }
                    //if (flagGetDataOver == true) { tsPressBarQry.Value = 100; break; }
                    if (tsPressBarQry.Value == 99)
                    {
                        tsPressBarQry.Value = 0;
                    }
                    tsPressBarQry.Value++;
                    Thread.Sleep(500);
                    Application.DoEvents();
                }
            }
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在C#中查询数据库并显示进度条,可以使用`BackgroundWorker`控件来实现。以下是实现步骤: 1. 创建一个`BackgroundWorker`控件和进度条控件。 ```c# BackgroundWorker worker = new BackgroundWorker(); ProgressBar progressBar = new ProgressBar(); ``` 2. 在`DoWork`事件中编写查询数据库的代码,并在查询过程中更新进度条的值。 ```c# worker.DoWork += (sender, e) => { using (SqlConnection conn = new SqlConnection(connectionString)) { conn.Open(); SqlCommand cmd = new SqlCommand("SELECT COUNT(*) FROM MyTable", conn); int count = (int)cmd.ExecuteScalar(); cmd.CommandText = "SELECT * FROM MyTable"; using (SqlDataReader reader = cmd.ExecuteReader()) { int i = 0; while (reader.Read()) { // 处理查询结果 i++; int progress = (int)((double)i / count * 100); worker.ReportProgress(progress); } } } }; ``` 3. 在`ProgressChanged`事件中更新进度条的值。 ```c# worker.ProgressChanged += (sender, e) => { progressBar.Value = e.ProgressPercentage; }; ``` 4. 启动`BackgroundWorker`控件并显示进度条。 ```c# worker.RunWorkerAsync(); progressBar.ShowDialog(); ``` 完整的代码如下: ```c# BackgroundWorker worker = new BackgroundWorker(); ProgressBar progressBar = new ProgressBar(); worker.DoWork += (sender, e) => { using (SqlConnection conn = new SqlConnection(connectionString)) { conn.Open(); SqlCommand cmd = new SqlCommand("SELECT COUNT(*) FROM MyTable", conn); int count = (int)cmd.ExecuteScalar(); cmd.CommandText = "SELECT * FROM MyTable"; using (SqlDataReader reader = cmd.ExecuteReader()) { int i = 0; while (reader.Read()) { // 处理查询结果 i++; int progress = (int)((double)i / count * 100); worker.ReportProgress(progress); } } } }; worker.ProgressChanged += (sender, e) => { progressBar.Value = e.ProgressPercentage; }; worker.RunWorkerAsync(); progressBar.ShowDialog(); ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值