欢迎来到山村网

c#异步读取数据库与异步更新ui的代码实现

2019-03-02 10:58:54浏览:87 来源:山村网   
核心摘要:这篇文章主要介绍了c#从数据库里取得数据并异步更新ui的方法,大家参考使用吧异步读取数据库,在数据绑定的时候会出现点问题,就是

这篇文章主要介绍了c#从数据库里取得数据并异步更新ui的方法,大家参考使用吧

异步读取数据库,在数据绑定的时候会出现点问题,就是窗体界面会无法关闭,要结束任务才能结束进程。例如下面代码首先按习惯的方法,设定线程更新UIa2.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# socket编程实现udp客户端

上一篇:

C#多线程界面卡死问题的解决方法

  • 信息二维码

    手机看新闻

  • 分享到
打赏
免责声明
• 
本文仅代表作者个人观点,本站未对其内容进行核实,请读者仅做参考,如若文中涉及有违公德、触犯法律的内容,一经发现,立即删除,作者需自行承担相应责任。涉及到版权或其他问题,请及时联系我们 xfptx@outlook.com