首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DataAdapter.Fill太慢

DataAdapter.Fill太慢
EN

Stack Overflow用户
提问于 2012-01-05 01:31:45
回答 3查看 10.7K关注 0票数 4

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

代码语言:javascript
复制
 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方法?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-01-05 01:38:10

您可以将DataGridView绑定到DataReader,但这可能也不会好到哪里去,因为将3000行数据加载到DataGridView中并不快。

票数 1
EN

Stack Overflow用户

发布于 2012-01-05 01:49:57

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

票数 1
EN

Stack Overflow用户

发布于 2012-01-05 01:51:35

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

这里有一个如何做到这一点的例子:BatchInsert

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8731241

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档