我知道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绑定到DataReader,但它可能没那么好,因为只需将3000行加载到DataGridView中就不会很快.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。