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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c# winform 如何批量更新数据库数据相关的知识,希望对你有一定的参考价值。

在winform中,如何在一个有上万或上百万条数据的数据库里,一次性更新大量数据,存储过程不考虑,有哪位朋友做过这样的项目,给指点一下,谢谢

在处理百万级的数据方面,也不一定需要存储过程,用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暴涨直到死机。
参考技术A 可以把查询到的数据存放到一张内存表DataTable中,然后拖一个DataGridView控件并绑定DataSource,然后在DataGridView中编辑完成后利用CommandBuilder返回给数据库 参考技术B 建议这个用线程,然后分别对这100万条数据分批处理。 参考技术C 1、分批量更新
2、用触发器
参考技术D 程序用循环实现。要不就是更新的时候where写的范围大一点~~

winform批量更新数据_长时间的执行会导致界面卡死

原文:winform批量更新数据_长时间的执行会导致界面卡死

  前言:使用winform触发一个事件后执行的代码,如果耗时非常长,则会导致窗口界面假死!  本人最近通过winform窗体执行一项:需要批量更新一批数据库的数据的操作的任务时,由于数据量达到百万级别,非常耗时,只能慢慢更新,慢慢执行。   

但是,在执行的过程遇到了一个奇葩的问题:窗体在调试状态下,代码可以慢慢循环执行,没出现异常。  但是我单独运行EXE程序时,就必现:程序假死,未响应状态。  

后台百度虽然没有找到直接的答案,但是也发现了原因:是因为在操作非常耗时时,程序会出现假死,解决方法也很简单:在你的耗时方法里,加上异步处理,不要让程序一直等待你的执行结果。

 

如下代码:

通过,异步Task.Run方法,让方法快速结束,不用登台中间即为耗时的操作更新过程,通过这样改造后,界面再也不卡死了,完美解决。

/// <summary>
        /// 临时方法-用于刷用户地址手机号数据
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnUpdateUserAddressPhone_Click(object sender, EventArgs e)
        
            this.txtActionInfomation.Text = $"方法开始";
            this.txtActionInfomation.Update();
            Task.Run(() => 
                //耗时代码
                do
                
                    //我的更新代码,需要分页获取并更新数据库,耗时长
                    //...
                    //...
                    this.txtActionInfomation.Text = $"已更新X条数据";
                    this.txtActionInfomation.Update();

                 while (true);
            );
            this.txtActionInfomation.Text = $"方法结束";
            this.txtActionInfomation.Update();

        

 

以上是关于c# winform 如何批量更新数据库数据的主要内容,如果未能解决你的问题,请参考以下文章

C# winform dataGridView批量数据修改

C#winform三层架构中如何实现将gridcontrol批量插入数据到数据库?

使用 c# winforms 将数据更新/保存到 SQL 数据库表

C# 自己写的Winform程序批量导入Excel文件到Oracle数据库的过程中,程序运行会很慢!而且Winform窗体会卡

winform批量更新数据_长时间的执行会导致界面卡死

C# winform程序 excel导入Sqlite数据库(批量新增),求大神看看我的代码