DataAdapter.填充速度太慢

本文关键字:速度 填充 DataAdapter | 更新日期: 2023-09-27 18:19:37

我知道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方法?

DataAdapter.填充速度太慢

您可以将DataGridView绑定到DataReader,但这可能不会更好,因为将3000行加载到DataGridView并不快速。

核心问题是一次为用户加载3000。无论如何加载300条记录,数据量都是问题所在。在sql查询中实现分页,以允许用户查看记录的子集。用户可以在需要时导航到更多记录。

使用BatchUpdate/BatchInsert。确保指定UpdateBatchSize=3000(记录数)

下面是一个如何执行的示例:BatchInsert