我知道 DataAdapters 有性能问题,但有什么方法可以更快地解决它吗?目前,DataAdapter.Fill 方法在 3000 条记录上需要 5-6 秒,这对我的应用程序来说太慢了。如果我删除 Fill 行并只执行 SQL(使用 SQLCE),则需要 20 毫秒,所以我猜查询不是问题。我试过在数据表上添加 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 方法?

最佳答案

您可以将 DataGridView 绑定(bind)到 DataReader,但它可能不会好得多,因为将 3000 行加载到 DataGridView 中并不快速。

关于c# - DataAdapter.Fill 太慢,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8731241/

10-13 07:43