号外号外: 原[图享网]更名为 码友网(codedefault.com) 啦,感谢大家一路上的陪伴与支持。代码的世界里,码友网与大家一起同行!

C#/.Net中使用事务[Transaction]快速批量插入数据记录到SQLite数据库[转载]

C#开发 作者: Rector 4204阅读 0评论 0收藏 收藏本文

郑重申明:本文未经许可,禁止任何形式转载

使用循环把上万的数据批量插入到SQLitte数据库是需要花费一定时间的,那么如果我们需要快速完成批量插入应该采集的解决方案有哪些呢?Transaction--事务。没错,C#/.Net中使用事务Transaction快速批量插入数据记录到SQLite数据库,可以有效地提高数据的处理速度,具体的实现语句如下:
            var stopwatch = new Stopwatch();
            using (var cmd = new SQLiteCommand(db_con))
            using (var transaction = db_con.BeginTransaction())
            {
                stopwatch.Reset();
                stopwatch.Start();
                foreach (var item in sorted)
                {
                    sql = string.Format("insert into db (st1, st2) values ('{0}', {1})", item.Key.Replace("'", "''"), item.Value);
                    cmd.CommandText = sql;
                    cmd.ExecuteNonQuery();
                    ++readCnt;
                    if (++readCnt % 1000000 == 0)
                    {
                        Console.Write("rDumped {0} lines...", readCnt);
                    }
                }
                Console.Write("rCommitting....");
                transaction.Commit();
                stopwatch.Stop();
                Console.Write("rDumped {0} lines using {1} seconds...", readCnt, stopwatch.Elapsed.TotalSeconds);
            }
本文转载至:转载自magic282.me 【C# .Net 中快速批量插入SQLite数据库:https://magic282.me/2015/06/insert-very-fast-in-csharp-dotnet-sqlite/】

阅读了该文章的人还浏览了...

本文永久链接码友网 » C#/.Net中使用事务[Transaction]快速批量插入数据记录到SQLite数据库[转载]

发布于: 2015-06-11 13:32:03
分享扩散:

文章评论

获取验证码