2

我正在开发一个 Winforms 应用程序,该应用程序当前使用 DataTables/DataAdapters,重点是将分隔文本导入/处理到嵌入式 SQL Server Compact 数据库中。

它有效,但我并不热衷于在我的应用程序中传递 DataRows 而不是 POCO。我想我会看看 ORM 的世界进行比较。NPoco 看起来不错,因为它明确支持 SQL Server Compact 和简单的语法。但...

        List<dummy> many = new List<dummy>(20000);

        for (int i = 0; i < 20000; i++)
        {
            dummy newdummy = new dummy();
            newdummy.dummytext = $"many-{i}";
            many.Add(newdummy);
        }

        using (Database db = new Database(CONNECTIONSTRING, DatabaseType.SQLCe))
        {
            System.Diagnostics.Debug.Print(DateTime.Now.ToString());
            db.InsertBulk(many);
            System.Diagnostics.Debug.Print(DateTime.Now.ToString());
        }

我被这速度有多慢吓到了!45 分钟挂钟时间。(得到的 20,000 条记录的获取时间是可以接受的,但仍然......)

作为比较,我可以在大约 2.5 秒内使用准备好的命令导入 20,000 多条记录并在循环中更新参数值。DataAdapter.Update 为 8 秒。

ORM 是否不适合我的用例,或者我应该尝试不同的 ORM,还是......?

4

1 回答 1

3

根据@John,此问题的解决方法是将批量插入包装在事务中。

    using (Database db = new Database(CONNECTIONSTRING, DatabaseType.SQLCe))
    {
        System.Diagnostics.Debug.Print(DateTime.Now.ToString());
        db.BeginTransaction();     // <------
        db.InsertBulk(many);
        db.CompleteTransaction();  // <------
        System.Diagnostics.Debug.Print(DateTime.Now.ToString());
    }
于 2017-03-07T14:15:02.393 回答