datagridview 大批量删除选中太慢了,怎么优化一下,求高手指点一下。

红蜻蜓888_r1i 2014-05-23 01:27:47



private void btn_selectitems_Click(object sender, EventArgs e)
{
this.dg_bt.Invoke((MethodInvoker)delegate()
{
for (int i = this.dg_bt.SelectedRows.Count; i > 0; i--)
{
dg_bt.Rows.RemoveAt(dg_bt.SelectedRows[i - 1].Index);
if (i % 10 == 0) Application.DoEvents();
}
});
}


我这种方法好慢,界面还是有点卡,如果不加处理事件,更卡的不像样了。删除几万条数据,我测试估计得20分钟,这也太慢了,有没有好点的办法呢,效率快些,还不卡的。求大侠指点!
...全文
336 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
於黾 2014-05-23
  • 打赏
  • 举报
回复
如果修改数据源也会导致datagridview刷新的话,可以先将datagridview的数据源置为null 等datatable刷新完了,重新绑定一下 这样不管你删除多少条数据,前台datagridview就只刷新2次.
於黾 2014-05-23
  • 打赏
  • 举报
回复
因为datagridview是每更新一次就刷新一次,必然慢. 你在后台直接对数据源进行操作,然后datagridview就只刷新一次
於黾 2014-05-23
  • 打赏
  • 举报
回复
dg_bt是什么?datagridview? 数据操作不要直接操作前台datagridview,你去删除后台的datatable,然后将datatable重新绑定到datagridview.
於黾 2014-05-23
  • 打赏
  • 举报
回复
前面说的就是后台数据源datatable啊. 难道你将数据源理解为数据库?
SeeYou孙悟空 2014-05-23
  • 打赏
  • 举报
回复
引用 10 楼 Z65443344 的回复:
[quote=引用 9 楼 moranhuoshou 的回复:] 这个情况,我去年的时候有遇见过。楼上说操作后台快,的确,是非常快,秒秒钟的事情。 难道前台就无法快吗? 是可以快的。 楼主,你用的是Removeat方法,这个最好是不要用的,因为你removeat 一下,gridview就会重新 排序一下index,这样会导致 gridview 非常慢,卡 ,你这里数据还很少,你试试100条以上就感觉到了。 那应该怎么搞呢?具体的话,代码是的确忘记了,1年多了,大概思路我还记得。 你用remove 操作datatalbe,然后 把操作datatable的操作全部完成后,再AcceptChanges(); 然后重新绑定到gridview 就可以了 。 希望能帮到你。
还不是一样要操作datatable...datatable是前台控件,能看见?[/quote] 这又不是UI,当然看不见。我的意思是,看楼主的图片,里卖的数据都是乱的,假的,我估计不是从数据库里读的,而是直接add进gd,何必和我较真。。。。如果是add进去的,一样可以取到datatable 来操作。
於黾 2014-05-23
  • 打赏
  • 举报
回复
引用 9 楼 moranhuoshou 的回复:
这个情况,我去年的时候有遇见过。楼上说操作后台快,的确,是非常快,秒秒钟的事情。 难道前台就无法快吗? 是可以快的。 楼主,你用的是Removeat方法,这个最好是不要用的,因为你removeat 一下,gridview就会重新 排序一下index,这样会导致 gridview 非常慢,卡 ,你这里数据还很少,你试试100条以上就感觉到了。 那应该怎么搞呢?具体的话,代码是的确忘记了,1年多了,大概思路我还记得。 你用remove 操作datatalbe,然后 把操作datatable的操作全部完成后,再AcceptChanges(); 然后重新绑定到gridview 就可以了 。 希望能帮到你。
还不是一样要操作datatable...datatable是前台控件,能看见?
SeeYou孙悟空 2014-05-23
  • 打赏
  • 举报
回复
这个情况,我去年的时候有遇见过。楼上说操作后台快,的确,是非常快,秒秒钟的事情。 难道前台就无法快吗? 是可以快的。 楼主,你用的是Removeat方法,这个最好是不要用的,因为你removeat 一下,gridview就会重新 排序一下index,这样会导致 gridview 非常慢,卡 ,你这里数据还很少,你试试100条以上就感觉到了。 那应该怎么搞呢?具体的话,代码是的确忘记了,1年多了,大概思路我还记得。 你用remove 操作datatalbe,然后 把操作datatable的操作全部完成后,再AcceptChanges(); 然后重新绑定到gridview 就可以了 。 希望能帮到你。
於黾 2014-05-23
  • 打赏
  • 举报
回复
datatable.Rows.RemoveAt() 其实用法是一样的
jimil 2014-05-23
  • 打赏
  • 举报
回复
delete from table where id in (1,2,3,5,6,9,122) 拼成这样就可以了。
enaking 2014-05-23
  • 打赏
  • 举报
回复
1楼和2楼方法都可以
exception92 2014-05-23
  • 打赏
  • 举报
回复
获取选定的行,根据id拼接sql语句,执行后重新绑定数据源。
红蜻蜓888_r1i 2014-05-23
  • 打赏
  • 举报
回复
引用 3 楼 Z65443344 的回复:
如果修改数据源也会导致datagridview刷新的话,可以先将datagridview的数据源置为null 等datatable刷新完了,重新绑定一下 这样不管你删除多少条数据,前台datagridview就只刷新2次.
噢,那只能弄数据源了。比较麻烦,不知道怎样,在数据源中删除选定的行号。
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView中添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)

110,502

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧