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

记得点赞收藏😄

相关推荐
Scout-leaf4 小时前
C#摸鱼实录——IoC与DI案例详解
c#
咕白m6256 小时前
使用 C# 在 Excel 中应用多种字体样式
后端·c#
Artech11 小时前
[MAF预定义的AIContextProvider-02]AgentSkillsProvider——将Agent Skills引入MAF
ai·c#·agent·agent skills·maf
2601_962072551 天前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
m0_547486661 天前
《C#语言程序设计与实践》 全套PPT课件
c语言·c#·c语言程序设计
叶帆1 天前
【YFIOs】用C#开发硬件之设备上云
开发语言·unity·c#
IT方大同1 天前
(嵌入式操作系统)信号量
嵌入式硬件·c#
z落落1 天前
C# FileStream文件流读取文件
开发语言·c#
yngsqq1 天前
排版优化 异形排版
c#
苦学的罐头1 天前
C# 协变与逆变深度解析:为什么 IEnumerable<T> 能转换,而 List<T> 不行?
开发语言·c#·list