- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Delphi 应用程序,它通过 FireDac 组件 TFDTable 将大约 200,000 条记录(大约 1GB)插入到 SQLite 数据库中。当它插入时,我可以看到应用程序内存不断增加,直到出现“内存不足错误”。我猜这与缓存和分页有关,但除了每 1000 条记录左右关闭并重新打开数据库之外,我找不到任何解决该问题的方法。想法?
已编辑...抱歉问了这个措辞薄弱的问题......代码很简单,所以我没有包含它,但看起来基本上是这样的:
procedure DoIt;
begin
myDB.Insert;
myDBField1.AsString := StringOfChar('-',1000);
myDB.Post;
end;
现在,我预计内存可能会增加,因为字符串可能会复制到数据库缓存。如果我使用 GetMemoryManagerState() 查看分配,我实际上可以看到这一点。我预计在某个时刻,当数据写入磁盘时,缓存中的内存将被刷新。然而,似乎并非如此。它会一直持续下去,直到我收到“内存不足”错误为止。
一般来说,除了在连接中选择sqlite以及向表中添加字段之外,大多数对象属性都设置为默认状态。
我知道这里没有太多可做的。但我也不认为这会失败,我希望有人可能遇到过类似的问题。
最佳答案
TFDTable是一个查询对象的薄包装器,可以构建用于操作底层 DBMS 表的 SQL 命令。它有自己的存储( Table 对象),用于存储获取到客户端的数据以及您插入的元组。但所有这些都在内存中,没有底层文件缓存。
尽管在插入时可以清除内部存储,TFDTable不是插入如此大量数据的好对象。更好地使用查询对象,如 TFDQuery与名为 Array DML 的批处理命令执行技术相结合可以为您带来真正的性能提升,即使对于本地 DBMS 引擎也是如此。和TFDQuery不会缓存插入的元组。
当您使用索引参数绑定(bind)时,FireDAC 原生支持 SQLite 的这种技术,例如此代码应插入 200 次批量的 1000 个唯一元组:
const
BatchSize = 1000;
TotalSize = 200000;
var
Batch: Integer;
Index: Integer;
begin
FDQuery.SQL.Text := 'INSERT INTO MyTable VALUES (:p1, :p2)';
FDQuery.Params.BindMode := pbByNumber;
FDQuery.Params.ArraySize := BatchSize;
for Batch := 0 to TotalSize div BatchSize - 1 do
begin
for Index := 0 to BatchSize - 1 do
begin
FDQuery.Params[0].AsIntegers[Index] := (Batch * BatchSize) + Index;
FDQuery.Params[1].AsWideStrings[Index] := 'Some Unicode string value';
end;
FDQuery.Execute(BatchSize, 0);
end;
end;
关于sqlite - 在 SQLite、FireDac、Delphi 中插入记录时内存不足,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45975298/
所以我正在为考试复习,并在 SQL 河(或荒地)中撞到了一块大石头 我制作了以下表格并插入了以下数据: create table Permissions ( fileName VARCHAR(
我有一个使用 maxWidth 定义的 jqueryui 对话框。 $("#myDialog").dialog({ autoOpen: false, width: 'a
注意:我遗漏了不相关的代码 所以我目前正在研究 CCC 1996 P1,这个问题的全部目的是能够计算一个整数输入是完美数、不足数还是充数。我上面列出的代码可以工作,但是我认为它太慢了。该代码会迭代每个
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我正在使用 Go 和 Redis 开发 API。问题是RAM使用不足,我找不到问题的根源。 TL;DR 版本 有数百/数千个哈希对象。每个 1 KB 的对象(键+值)占用大约 0.5 MB 的 RAM
在我的 GCE Kubernetes 集群上,我无法再创建 pod。 Warning FailedScheduling pod (www.caveconditions.com-f1be467e3
当我尝试在EKS Fargate群集上安装指标服务器时,它抛出错误: 0/4 nodes are available: 4 Insufficient pods. 按照以下说明从此处安装指标服务器:ht
遍布this document Apple 提到 iOS 在某些情况下会终止应用程序,最常见的原因似乎是释放一些 RAM。这会导致未实现状态恢复的应用程序出现问题——用户正在处理和暂时离开的一些内容可
尝试处理一个10分钟的音频文件时出现以下错误。我刚刚开始使用Google Cloud产品,所以我是唯一访问此资源的人。我怎么可能超出配额?配额设置为其默认值,我认为我没有任何限制。还有其他原因吗? 我
R 语言让我感到困惑。实体有模式和类,但即使这样也不足以完全描述实体。 这个answer说 In R every 'object' has a mode and a class. 所以我做了这些实验:
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
在 how-do-i-access-the-stackoverflow-api-from-mathematica我概述了如何使用 SO API 让 Mathematica 制作一些有趣的顶级回答者声誉
所以在 GKE 上,我有一个 Node.js app,每个 pod 使用大约:CPU(cores): 5m, MEMORY: 100Mi 但是我只能为每个 Node 部署 1 个 pod。我使用的是
我正在使用 async.eachOfSeries 超过 300 个数组并请求一些 GA api,它工作正常但有时我会收到错误.. UnhandledPromiseRejectionWarning:错误
我正在尝试在 AWS ec2 上托管的 kubernetes 集群上使用 mr3 设置配置单元。当我运行命令 run-hive.sh 时,Hive 服务器启动,并且 master-DAg 被初始化,但
创建订阅时有时会出现以下错误: Insufficient tokens for quota 'administrator' and limit 'CLIENT_PROJECT-100s' of ser
我是一名优秀的程序员,十分优秀!