dataGridView1数据刷新慢

huangxi79 2012-10-04 03:29:29
我的思路是利用timer1,每3秒从数据库里读一条数据,然后更新SMS_SEND_STATE 的状态,但dataGridView1一开始就花了10几秒钟才能显示数据,然后更新数据后,dataGridView1的值没有变,而进数据库查看却发现值已经改变了;关于这个问题,百度出来的,都是要设置DataGridView的AutoSizeColumnsMode等,但也不行,也有说分页显示,但我每次只取一条记录,没必要分页吧,请给位高手给我意见,具体代码如下:
private void Form1_Load(object sender, EventArgs e)
{

ConnectionString = "Data Source=hhk;user=erp;password=hhk7845475;";//写连接串
conn=new OracleConnection(ConnectionString);//创建一个新连接
conn.Open();
}

private void timer1_Tick(object sender, EventArgs e)
{
string sql = "SELECT * FROM SMS_INFO WHERE (SMS_SEND_STATE = '待发') AND (ROWNUM < 2) ";

//OracleCommand cmd = conn.CreateCommand();
//cmd.CommandText = sql;
//OracleDataReader odr = cmd.ExecuteReader();//创建一个OracleDateReader对象

adapter = new OracleDataAdapter(sql, conn);
OracleCommandBuilder sqlBulider = new OracleCommandBuilder(adapter);

ds = new DataSet("GenStgReferenz");
adapter.Fill(ds, "GenStgReferenz");
this.dataGridView1.DataSource = ds.Tables["GenStgReferenz"];
int i = this.dataGridView1.Rows.Count;
if (i > 1)
{
this.dataGridView1.Rows[0].Cells[7].Value = "已发";
this.dataGridView1.Rows[0].Cells[8].Value = System.DateTime.Now.ToString("yyyy-MM-dd hh:MM:ss");
}
else
{

label1.Text = "无数据";

}
adapter.Update(ds.Tables["GenStgReferenz"]);
}
...全文
210 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
ggewt2td 2012-10-05
  • 打赏
  • 举报
回复
string sql = "SELECT top 1 * FROM SMS_INFO WHERE (SMS_SEND_STATE = '待发') ";

用 top 1 就行了,为什么要用 AND (ROWNUM < 2) ?


huangxi79 2012-10-04
  • 打赏
  • 举报
回复
楼上高手,我是临时用C#的,请教如何重新绑定数据集?最好能帮我改改我的代码。谢谢了!
bdmh 2012-10-04
  • 打赏
  • 举报
回复
取得新数据就要重新绑定数据集,才会显示新数据
huangxi79 2012-10-04
  • 打赏
  • 举报
回复
哦,忘了说了,在查询分析器里面显示好快的。然后用delphi,PowerBuilder实现上面的功能也是很快的,基本上一运行就有数据出来了。

110,567

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧