在我的WinForms应用程序中,我将大量数据从二进制文件加载到SQLite DB中。我在数据库上进行查找,以确定是否要添加每个新数据。
If LookUpResult Then
AddNewData
Else
DiscardNewData
End If这很慢。插入似乎需要很长时间。我应该使用DataTable或DataSet类将数据加载到内存中,然后作为后台任务写入SQLite DB吗?或者,一次从DataTable对象插入多个行的成本会更低吗?
我之前将所有数据加载到一个自定义类中,这很快,但可能会达到内存限制,因此移动到DB。我本以为SQLite会将插入内容缓存到内存中,但事实似乎并非如此。
谢谢你的建议。
发布于 2012-11-26 16:54:58
为确保崩溃一致性,更改后的数据将在每个事务结束时与磁盘同步。如果您不使用显式事务,则每个命令将获得其自己的自动事务,这意味着您将获得每个命令的同步开销。
对所有插入操作使用一个事务。(只要您通过相同的数据库连接,您自己的更改就会可见。)
https://stackoverflow.com/questions/13550612
复制相似问题