C# 数据适配器。填充速度太慢

C# 数据适配器。填充速度太慢,c#,performance,datagridview,sql-server-ce,dataadapter,C#,Performance,Datagridview,Sql Server Ce,Dataadapter,我知道DataAdapter存在性能问题,但是有没有其他方法可以更快地解决这个问题?目前,DataAdapter.Fill方法在3000条记录上花费了5-6秒,这对于我的应用程序来说太慢了。如果我删除Fill行,只执行SQL(使用SQLCE),需要20毫秒,所以我猜查询不是问题所在。我尝试在datatable上添加BeginLoadData,但这对性能没有影响 using (SqlCeConnection con = new SqlCeConnection(conString)) {

我知道DataAdapter存在性能问题,但是有没有其他方法可以更快地解决这个问题?目前,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
方法?

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

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

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


下面是一个如何执行此操作的示例:

可能是连接速度有问题?能否将代码粘贴到声明和填充dTable的位置。。?此外,如果您正在执行诸如更新、删除或插入之类的操作,请改用数据读取器…..更快我添加了额外的代码并删除了
BeginLoadData
。我将数据库移动到本地计算机以确保它没有连接问题@DJ Kraze,我认为更新、删除和插入主要是针对DataAdapter的,而DataReader是针对只读内容的?如果您注释掉
dataGridView1.DataSource=dTable行和离开
dAdapter.Fill(数据表)?我想它是绑定数据做DGV可能很慢,不能填充表格。@mj82-不,我想它可能也是DGV,但如果我删除数据源,时间是一样的。这肯定是导致延迟的填充方法。有没有更好的替代方法来代替DGV,允许用户以类似Excel的方式编辑数据?没有免费的。您可以尝试Telerik RadGridView或DevExpress XtraGrid。另一个选择是进行一些分页。。此外,我会亲自更改该数据表并使用Datareader。。另外,您是否意识到可以将数据网格绑定到列表,而且可能会更快。。。仅供参考。@DJKraze-DataReader在这里的速度不是很快。这和DataReader需要一个开放的连接数据库连接。绑定到UI时保持其打开没有意义。将记录加载到DTO中,释放命令,然后绑定到UI。我使用的是SqlCE,不是sqlserver。另外,SqlCE不支持存储过程。很抱歉,我没有意识到您正在使用SqlCE。不用担心,我已经了解了UpdateBatchSize,以供将来参考;)