c# winform 如何批量更新数据库数据

在winform中,如何在一个有上万或上百万条数据的数据库里,一次性更新大量数据,存储过程不考虑,有哪位朋友做过这样的项目,给指点一下,谢谢... 在winform中,如何在一个有上万或上百万条数据的数据库里,一次性更新大量数据,存储过程不考虑,有哪位朋友做过这样的项目,给指点一下,谢谢 展开
 我来答
匿名用户
2013-04-09
展开全部
在处理百万级的数据方面,也不一定需要存储过程,用C#一样可以;ADO.NET提供了常用对象即可解决,就是数据适配器,在处理海量数据的时候,表现还是可圈可点的。先指定参数,接着一个循环,例: for (int i = 0; i < 100; i++)
{
dataset.Tables[0].Rows[i].BeginEdit();
dataset.Tables[0].Rows[i]["time"] = "2222-22-22 22:22:22";
dataset.Tables[0].Rows[i]["value"] = 100;
dataset.Tables[0].Rows[i]["id"] = "ID"+(i+10000);
dataset.Tables[0].Rows[i].EndEdit();
}接着一次提交更新就OK了数据适配器.Update(dataset.Tables[0]);然后释放资源,把数据集合适配器的资源都释放掉,连接也返回池中。 dataset.Tables[0].Clear();
适配器.Dispose
dataset.Dispose要注意的是,你在取记录填充到数据集里面的时候,不要一次去提取100万条,那样你的数据库引擎会不堪重负的。要根据你的硬件配置,每次提取适量的数据,如果配置不是很高,一次提取个500-600就行了,这样很快就能把数据在循环中处理完毕而不是卡到CPU暴涨直到死机。
匿名用户
2013-04-09
展开全部
可以把查询到的数据存放到一张内存表DataTable中,然后拖一个DataGridView控件并绑定DataSource,然后在DataGridView中编辑完成后利用CommandBuilder返回给数据库
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2013-04-09
展开全部
建议这个用线程,然后分别对这100万条数据分批处理。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
q584847415
2013-04-09
知道答主
回答量:70
采纳率:0%
帮助的人:18.1万
展开全部
1、分批量更新
2、用触发器
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
oxuebino
2013-04-12 · 超过19用户采纳过TA的回答
知道答主
回答量:97
采纳率:0%
帮助的人:53.6万
展开全部
程序用循环实现。要不就是更新的时候where写的范围大一点~~
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式