C# 异步读取数据库里面的数据与绑定UI的解决办法
来源:互联网 发布:2016订单系统源码 编辑:程序博客网 时间:2024/06/06 09:11
异步读取数据库,在数据绑定的时候会出现点问题,就是窗体界面会无法关闭,要结束任务才能结束进程。例如下面代码
首先按习惯的方法,设定线程更新UI
a2.CheckForIllegalCrossThreadCalls = false; //a2为窗体名称
下面的代码就是从数据库里取得数据并绑定
private void button1_Click(object sender, EventArgs e)
{
SqlConnection con;
SqlCommand com;
try
{
con = new SqlConnection("UID=sa;Password=123;Initial Catalog=AD;Data Source=192.168.1.1;Asynchronous Processing=true");
con.Open();
com = new SqlCommand("select top 100 * from tb_user", con);
com.BeginExecuteReader(new AsyncCallback(delDataBin), com);
}
catch (Exception ex)
{
MessageBox.Show("程序发生错误,信息: " + ex.Message);
}
}
private void delDataBin(IAsyncResult ar)
{
if (ar.IsCompleted)
{
SqlCommand com = (SqlCommand)ar.AsyncState;
SqlDataReader dr = com.EndExecuteReader(ar);
DataTable dt = new DataTable();
dt.Load(dr);
dr.Close();
this.dataGridView1.DataSource = dt; //绑定数据
}
}
到这里完成的绑定的工作,运行查看一下效果,其实这样是会出现窗体假死的现象。
下面通过Invoke 来实现
首先声明委托 public delegate void updateDG(DataTable dt);
然后通过dataBin来绑定DataGridView
public void dataBin(DataTable dt)
{
dataGridView1.DataSource = dt;
return;
}
在线程里面调用下面方法
//绑定数据
if (this.InvokeRequired)
{
updateDG ur = new updateDG(dataBin);
this.Invoke(ur, dt);
}
完整的代码如下:
private void button1_Click(object sender, EventArgs e)
{
SqlConnection con;
SqlCommand com;
try
{
con = new SqlConnection("UID=sa;Password=123;Initial Catalog=AD;Data Source=192.168.1.1;Asynchronous Processing=true");
con.Open();
com = new SqlCommand("select top 100 * from tb_user", con);
com.BeginExecuteReader(new AsyncCallback(delDataBin), com);
}
catch (Exception ex)
{
MessageBox.Show("程序发生错误,信息: " + ex.Message);
}
}
private void delDataBin(IAsyncResult ar)
{
if (ar.IsCompleted)
{
SqlCommand com = (SqlCommand)ar.AsyncState;
SqlDataReader dr = com.EndExecuteReader(ar);
DataTable dt = new DataTable();
dt.Load(dr);
dr.Close();
//this.dataGridView1.DataSource = dt;//绑定数据
if (this.InvokeRequired)
{
updateDG ur = new updateDG(dataBin);
this.Invoke(ur, dt);
}
}
}
public delegate void updateDG(DataTable dt);
public void dataBin(DataTable dt)
{
dataGridView1.DataSource = dt;
return;
}
查运行查看一下,你就会发现结果了
首先按习惯的方法,设定线程更新UI
a2.CheckForIllegalCrossThreadCalls = false; //a2为窗体名称
下面的代码就是从数据库里取得数据并绑定
private void button1_Click(object sender, EventArgs e)
{
SqlConnection con;
SqlCommand com;
try
{
con = new SqlConnection("UID=sa;Password=123;Initial Catalog=AD;Data Source=192.168.1.1;Asynchronous Processing=true");
con.Open();
com = new SqlCommand("select top 100 * from tb_user", con);
com.BeginExecuteReader(new AsyncCallback(delDataBin), com);
}
catch (Exception ex)
{
MessageBox.Show("程序发生错误,信息: " + ex.Message);
}
}
private void delDataBin(IAsyncResult ar)
{
if (ar.IsCompleted)
{
SqlCommand com = (SqlCommand)ar.AsyncState;
SqlDataReader dr = com.EndExecuteReader(ar);
DataTable dt = new DataTable();
dt.Load(dr);
dr.Close();
this.dataGridView1.DataSource = dt; //绑定数据
}
}
到这里完成的绑定的工作,运行查看一下效果,其实这样是会出现窗体假死的现象。
下面通过Invoke 来实现
首先声明委托 public delegate void updateDG(DataTable dt);
然后通过dataBin来绑定DataGridView
public void dataBin(DataTable dt)
{
dataGridView1.DataSource = dt;
return;
}
在线程里面调用下面方法
//绑定数据
if (this.InvokeRequired)
{
updateDG ur = new updateDG(dataBin);
this.Invoke(ur, dt);
}
完整的代码如下:
private void button1_Click(object sender, EventArgs e)
{
SqlConnection con;
SqlCommand com;
try
{
con = new SqlConnection("UID=sa;Password=123;Initial Catalog=AD;Data Source=192.168.1.1;Asynchronous Processing=true");
con.Open();
com = new SqlCommand("select top 100 * from tb_user", con);
com.BeginExecuteReader(new AsyncCallback(delDataBin), com);
}
catch (Exception ex)
{
MessageBox.Show("程序发生错误,信息: " + ex.Message);
}
}
private void delDataBin(IAsyncResult ar)
{
if (ar.IsCompleted)
{
SqlCommand com = (SqlCommand)ar.AsyncState;
SqlDataReader dr = com.EndExecuteReader(ar);
DataTable dt = new DataTable();
dt.Load(dr);
dr.Close();
//this.dataGridView1.DataSource = dt;//绑定数据
if (this.InvokeRequired)
{
updateDG ur = new updateDG(dataBin);
this.Invoke(ur, dt);
}
}
}
public delegate void updateDG(DataTable dt);
public void dataBin(DataTable dt)
{
dataGridView1.DataSource = dt;
return;
}
查运行查看一下,你就会发现结果了
- C# 异步读取数据库里面的数据与绑定UI的解决办法
- C# 异步读取数据库里面的数据与绑定UI的解决办法
- iFrame页面数据的绑定与读取
- Listview 里面的checkbox怎么与数据库绑定
- C#读取URL里面的XML数据问题
- ASP逐条读取ACCESS数据库里面的数据
- 网站打开首页时如何读取数据库里面的数据
- xml里面数据的读取
- C# 中读取数据库数据的问题
- C#异步读取数据
- [.net] asp.net入门----数据的读取与绑定
- ListView的数据绑定与点击事件读取信息
- C# 读取Resurces里面的文件
- vb+MAPX开发打开ACESS数据库并于里面的X,Y 数据绑定
- C# datagridviewcomboxcolumn数据的绑定与值的显示
- c# SQl server数据库与下拉框的绑定
- 动态读取table里面的数据
- js怎样读取json里面的数据 :
- 如何用C#设置IE的代理
- 用C#实现Web代理服务器
- Web服务器控件(四)
- C#多线程与UI响应
- C#枚举所有的窗体
- C# 异步读取数据库里面的数据与绑定UI的解决办法
- Label Web服务器控件
- Button Web服务器控件(六)
- 通过SmtpClient发送Exchange会议邮件
- ALE and IDocs 入门指南——一步步操作
- 任何人都可合法实现C#与CLI规范
- Button Web服务器控件(七)
- LinkButton Web服务器控件(八)
- C#中调用Outlook API 发起会议