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

记得点赞收藏😄

相关推荐
wangnaisheng2 小时前
【C#】GraphicsPath的用法
c#·gdi
bianguanyue8 小时前
SQLite密码修改故障排查:RSA加密随机性导致的数据库匹配问题
数据库·sqlite·c#
R-sz9 小时前
导出word并且插入图片
开发语言·c#·word
CodeCraft Studio13 小时前
PPT处理控件Aspose.Slides教程:使用 C# 将 PPTX 转换为 EMF
c#·powerpoint·ppt·aspose·ppt格式转换
future141214 小时前
游戏开发日记7.12
数据结构·学习·c#·游戏开发
洁辉15 小时前
C# & .NET 面试深度复习指南
面试·c#·.net
_oP_i17 小时前
无法找到来自源 EdgeWebView,实际安装了,偶尔出现
c#
阿蒙Amon18 小时前
C#类型转换:从基础到进阶的全景解析
开发语言·c#
时光追逐者1 天前
一款开源免费、通用的 WPF 主题控件包
开源·c#·.net·wpf
张人玉1 天前
c#中Random类、DateTime类、String类
开发语言·c#