【C#动态加载数据】“防界面卡死”

废话不多说,直接开始

添加引用

using System.ComponentModel

完整代码

csharp 复制代码
using System;  
using System.ComponentModel;  
using System.Data;  
using System.Windows.Forms;  
using System.Data.SqlClient; // 引入SqlClient命名空间以使用ADO.NET  
  
public partial class YourForm : Form  
{  
    private BackgroundWorker backgroundWorker;  
  
    public YourForm()  
    {  
        InitializeComponent();  
        backgroundWorker = new BackgroundWorker();  
        backgroundWorker.WorkerReportsProgress = true; // 如果你不需要报告进度,可以设置为false  
        backgroundWorker.DoWork += BackgroundWorker_DoWork;  //task开始执行方法
        backgroundWorker.ProgressChanged += new ProgressChangedEventHandler(DW_Change_Progress);//进度汇报事件
        backgroundWorker.RunWorkerCompleted += BackgroundWorker_RunWorkerCompleted;  //task结束事件
    }  
  
    private void StartButton_Click(object sender, EventArgs e)  
    {  
        List<string> param= new List<string>(){"back_work_intput_parameter"};
        if (!backgroundWorker.IsBusy)  
        {  
            // 在开始工作之前,可以禁用UI元素以防止用户进行其他操作  
            StartButton.Enabled = false;  
            backgroundWorker.RunWorkerAsync(param); // 启动后台工作  
        }  
    }  
  
    private void BackgroundWorker_DoWork(object sender, DoWorkEventArgs e)  
    {  
        List<string> param = (List<string>)e.Argument;//获取入参
        if (param.Count < 1) return;
        
        // 这个方法将在后台线程上执行  
        try  
        {  
            using (SqlConnection connection = new SqlConnection(YourConnectionString)) // 替换为你的连接字符串  
            {  
                connection.Open();  
                using (SqlCommand command = new SqlCommand("SELECT * FROM YourTable", connection)) // 替换为你的SQL查询和表名  
                {  
                    using (SqlDataReader reader = command.ExecuteReader())  
                    {  
                        DataTable dataTable = new DataTable();  
                        dataTable.Load(reader);  
                        // 将DataTable作为结果传递给RunWorkerCompleted事件处理程序  
                        e.Result = dataTable;  
                    }  
                }  
            }  
        }  
        catch (Exception ex)  
        {  
            // 将异常传递给RunWorkerCompleted事件处理程序  
            e.Result = ex;  
        }  
    }  
    public void DW_Change_Progress(object sender, ProgressChangedEventArgs e)
    {
        Progress.Value = (float)e.ProgressPercentage /   (float)db_name_list.Count;   
    }
    private void BackgroundWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)  
    {  
        // 这个方法将在UI线程上执行,当DoWork完成时  
        if (e.Error != null)  
        {  
            // 处理异常  
            MessageBox.Show(e.Error.Message);  
        }  
        else  
        {  
            // 获取并处理数据  
            DataTable dataTable = e.Result as DataTable;  
            if (dataTable != null)  
            {  
                // 更新UI,例如将数据绑定到DataGridView等控件上  
                yourDataGridView.DataSource = dataTable;  
            }  
        }  
        finally  
        {  
            // 重新启用UI元素  
            StartButton.Enabled = true;  
        }  
    }  
}

记得点赞收藏😄

相关推荐
SongYuLong的博客5 小时前
C# (定时器、线程)
开发语言·c#
百锦再6 小时前
详解基于C#开发Windows API的SendMessage方法的鼠标键盘消息发送
windows·c#·计算机外设
无敌最俊朗@7 小时前
unity3d————协程原理讲解
开发语言·学习·unity·c#·游戏引擎
程序设计实验室7 小时前
在网页上调起本机C#程序
c#
Crazy Struggle10 小时前
.NET 8 强大功能 IHostedService 与 BackgroundService 实战
c#·.net·.net core
fs哆哆11 小时前
C#编程:优化【性别和成绩名次】均衡分班
开发语言·c#
fathing12 小时前
c# 调用c++ 的dll 出现找不到函数入口点
开发语言·c++·c#
wyh要好好学习14 小时前
C# WPF 记录DataGrid的表头顺序,下次打开界面时应用到表格中
开发语言·c#·wpf
AitTech14 小时前
C#实现:电脑系统信息的全面获取与监控
开发语言·c#
咩咩觉主14 小时前
尽量通俗易懂地概述.Net && U nity跨语言/跨平台相关知识
unity·c#·.net·.netcore