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

2025-02-25 04:27:20
推荐回答(5个)
回答1:

在处理百万级的数据方面,也不一定需要存储过程,用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暴涨直到死机。

回答2:

可以把查询到的数据存放到一张内存表DataTable中,然后拖一个DataGridView控件并绑定DataSource,然后在DataGridView中编辑完成后利用CommandBuilder返回给数据库

回答3:

建议这个用线程,然后分别对这100万条数据分批处理。

回答4:

1、分批量更新
2、用触发器

回答5:

程序用循环实现。要不就是更新的时候where写的范围大一点~~