【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;  
        }  
    }  
}

记得点赞收藏😄

相关推荐
Aimeast2 小时前
关于选择最佳.NET Core SSH服务器库的全面分析
c#·ssh
蒋劲豪3 小时前
WPF项目暴露WebApi接口;WinForm项目暴露WebApi接口;C#项目暴露WebApi接口;
开发语言·c#·wpf
code bean4 小时前
【C# 数据结构】队列 FIFO
开发语言·数据结构·c#
时光追逐者6 小时前
推荐几款开源免费的 .NET MAUI 组件库
microsoft·开源·c#·.net·.net core·maui
软件黑马王子8 小时前
C#初级教程(1)——C# 与.NET 框架:探索微软平台编程的强大组合
开发语言·c#
shepherd枸杞泡茶8 小时前
第3章 3.2 配置系统 .NET Core配置系统
后端·c#·asp.net·.net
编程乐趣10 小时前
一文掌握DeepSeek本地部署+Page Assist浏览器插件+C#接口调用+局域网访问!全攻略来了!
开发语言·c#
我是苏苏10 小时前
C#基础:使用Linq进行简单去重处理(DinstinctBy/反射)
开发语言·c#·linq
小小码农(找工作版)10 小时前
C#前端开发面试题
开发语言·c#
局外人_Jia12 小时前
C# 十六进制字符串转换为十进制
服务器·开发语言·c#