gpt4 book ai didi

c# - 如何同时运行两个或多个sql查询?

转载 作者:行者123 更新时间:2023-11-29 18:05:13 24 4
gpt4 key购买 nike

我想在不同的线程中同时运行更多查询。我正在使用后台 worker 来解决这个问题!我的问题是:是否有更好的方法来委托(delegate) UI 元素,或者它是否像我那样正确?

    private void mainform_Load(object sender, EventArgs e)
{


if (bscan_backgroundworker.IsBusy == false)
{
bscan_backgroundworker.RunWorkerAsync();
}

if (bscan2_backgroundworker.IsBusy == false)
{
bscan2_backgroundworker.RunWorkerAsync();
}

}

private void bscan_backgroundworker_DoWork(object sender, DoWorkEventArgs e)
{
bscan();

}

private void bscan2_backgroundworker_DoWork(object sender, DoWorkEventArgs e)
{
bscan2();

}

private void bscan()
{

string query = "Select * from table_name";
MySqlConnection mysqlconn_to_db = new MySqlConnection(connectionstring);
try
{
mysqlconn_to_db.Open();
using (MySqlCommand command = new MySqlCommand(query, mysqlconn_to_db))
{
command.ExecuteNonQuery();

using (MySqlDataAdapter adapter = new MySqlDataAdapter(command))
{
DataTable datatable = new DataTable();
adapter.Fill(datatable);


if (this.InvokeRequired)
{
this.Invoke(new MethodInvoker(delegate ()
{
dataGridView1.DataSource = datatable;
dataGridView1.Refresh();
label2.Text = dataGridView1.Rows[Convert.ToInt16(label1.Text)].Cells[0].Value.ToString();
}));
}
else
{
dataGridView1.DataSource = datatable;
dataGridView1.Refresh();
label2.Text = dataGridView1.Rows[Convert.ToInt16(label1.Text)].Cells[0].Value.ToString();
}


adapter.Dispose();
}

}
}
catch (Exception ex)
{
messagebox(ex.Message);
}


}

bscan2() 方法与 bscan() 几乎相同,但查询和数据 GridView 不同。有没有更有效的方法来做到这一点,或者可以吗?

最佳答案

您的 BackgroundWorker 解决方案不一定是坏方案,但有一些新的和改进的方法可以处理 C# 中的异步编程。强烈建议您查看async and await 。这可能不太直接适用于您在这种情况下想要完成的任务,因为您似乎不想等待一种方法完成,因此还建议您查看 Task Parallel Library (TPL) ,特别是 Task.Run() 。甚至还有一个叫做Parallel LINQ的东西这是专门用于处理异步查询的。

关于c# - 如何同时运行两个或多个sql查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47929700/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com