DataAdapter.Fill太慢了

时间:2012-01-04 17:31:45

标签: c# performance datagridview sql-server-ce dataadapter

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

3 个答案:

答案 0 :(得分:1)

您可以将DataGridView绑定到DataReader,但它可能不会好多了,因为将数据行加载到DataGridView中并不是很快。

答案 1 :(得分:1)

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

答案 2 :(得分:0)

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

以下是有关如何操作的示例:BatchInsert