使用循环把上万的数据批量插入到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/】
版权声明:本作品系原创,版权归码友网所有,如未经许可,禁止任何形式转载,违者必究。
发表评论
登录用户才能发表评论, 请 登 录 或者 注册