我正在开发一个 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,还是......?