我知道DataAdapters存在性能问题,但有没有什么方法可以更快地解决它?目前,DataAdapter.Fill方法在3000条记录上需要5-6秒的时间,这对我的应用程序来说太慢了。如果我删除
Fill
行并只执行SQL(使用SQLCE),则需要20毫秒,因此我猜测查询不是问题所在。我尝试在datatable上添加BeginLoadData
,但对性能没有任何影响。 using (SqlCeConnection con = new SqlCeConnection(conString))
{
con.Open();
using (SqlCeDataAdapter dAdapter= new SqlCeDataAdapter())
{
using (SqlCeCommand com = new SqlCeCommand(query, con))
{
com.Parameters.Add("uname", textBox1.Text);
dAdapter.SelectCommand = com;
dAdapter.SelectCommand.Connection = con;
DataTable dTable = new DataTable();
dAdapter.Fill(dTable);
dataGridView1.DataSource = dTable;
}
}
}
有更好的方法来填充DataGridView或加快Fill方法吗?
BeginLoadData
。我将数据库移动到我的本地机器上,以确保它不是连接问题。@DJ Kraze,我认为更新、删除和插入主要是针对数据适配器,而数据读取器则用于只读操作? - SkoderdataGridView1.DataSource = dTable;
这一行,只留下dAdapter.Fill(dTable);
,那么会发生什么?我猜绑定数据到 DGV 可能会很慢,而不是填充表格。 - mj82