c# winform 如何批量更新数据库数据
在winform中,如何在一个有上万或上百万条数据的数据库里,一次性更新大量数据,存储过程不考虑,有哪位朋友做过这样的项目,给指点一下,谢谢...
在winform中,如何在一个有上万或上百万条数据的数据库里,一次性更新大量数据,存储过程不考虑,有哪位朋友做过这样的项目,给指点一下,谢谢
展开
6个回答
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暴涨直到死机。
{
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万条数据分批处理。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
1、分批量更新
2、用触发器
2、用触发器
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
程序用循环实现。要不就是更新的时候where写的范围大一点~~
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询