请教c#、vb.net高手:DataGridViewRow删除行速度问题。

场景很简单,一个datagridview绑定了一个查询到的datatable,大概有几百到几千行,用户选中任意行,点击删除。要达到的目的是同时删除数据库和界面的选中行(目... 场景很简单,一个datagridview绑定了一个查询到的datatable,大概有几百到几千行,用户选中任意行,点击删除。要达到的目的是同时删除数据库和界面的选中行(目的是一致)。我的方法是先删除数据库再删除界面。在删除数据库的过程大概是每秒1000行,很快,但是删除界面,每秒大概只有1行,用的是for each 和 remove(row)。
重新查询不用建议了,因为数据量比较大。我现在想提升更新界面的速度,怎么办?
展开
 我来答
SimpleShi
2013-05-04 · TA获得超过371个赞
知道小有建树答主
回答量:396
采纳率:0%
帮助的人:296万
展开全部
给你一个思路,你可以这样:
1,先删除DataGridView里面的数据,不要遍历删除,而是根据当前的要删除的index去删除,但是你取回来的数据要放在一个临时表里面,以便于操作。
2,通过线程并发的方式去删除数据库里面的数据,

这样就可以节省出来很大一部分时间,
tystq
2013-05-04 · TA获得超过1201个赞
知道小有建树答主
回答量:943
采纳率:100%
帮助的人:825万
展开全部
直接删除datatable中的行啊,非常快的,然后再绑定
datatable也是可以复制的哦,为了安全,先复制一份,等于直接操作内存
追问
你好,我准备采用这种对datatable的操作,然后重新绑定。
还有个问题,在遍历datatable的时候,我如何知道哪些行是被选中的?有没有一种方便的方法可以得到?还是必须在界面去获取这个index的集合?界面的index一定是和datatable一样的么?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式