- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
根据 ZODB documentation :
A savepoint allows a data manager to save work to its storage without committing the full transaction." "Savepoints are also useful to free memory that would otherwise be used to keep the whole state of the transaction.
根据很有启发性的文章When to commit data in ZODB (马丁·彼得斯):
... a point during the whole transaction where you can ask for data to be temporarily stored on disk. [...]
One thing a savepoint does, is call for a garbage collection of the ZODB caches, which means that any data not currently in use is removed from memory.
问题是,我需要在一次交易中存储很多项目,如下所示:
for i, item in enumerate(aLotOfItems):
database[i]=item
if i % 10000 ==0:
transaction.savepoint(True)
transaction.commit()
我有点希望 transaction.savepoint 以与 bsddb3.db.Db.sync
相同的方式工作。当 Db.sync()
被调用时,数据库被刷新,你可以观察到。但是,当设置保存点时,显然数据库和 tmp 文件都不会增长或改变大小,直到 transaction.commit()
。
我真的很困惑:
设置保存点后实际发生了什么?
它与提交/刷新数据库有何不同?
如果“数据暂存在磁盘”,保存点将数据写到哪里?
我可以指望保存点真正意义上的“释放内存”吗?
最佳答案
保存点最初的主要用途是能够回滚事务的部分。
假设您想接受大量的日志条目,但需要将它们分批处理到数据库中:
for batch in per_batch(log_entries):
sp = transaction.savepoint()
try:
process_batch(batch)
except BatchFailedException:
sp.rollback()
transaction.commit()
raise
现在事务已经提交,除了最后一批已经回滚。
这是使用保存点的最初原因。设置保存点具有触发 ZODB 缓存垃圾收集运行的副作用。
ZODB 保存最近访问过的对象的缓存。这包括在当前交易期间实际上没有改变的对象;您只是从数据库中检索它们,使用它们的数据,然后停止直接引用它们。 ZODB 存储一个对象图;一个对象引用其他对象,而其他对象又引用其他对象。这些对象中的每一个,如果它们继承自 Persistent
基类,都是单独的 ZODB 记录。当你遍历图时,这些对象都被加载到内存中。
如果它们没有改变,GC 运行将再次从内存中清除它们。再次遍历对象图会将它们再次加载到内存中,但在保存点期间清除它们可以节省内存。
保存点数据本身存储在磁盘上的 TmpStorage
文件中,在您的 TEMP
目录中。这使用 tempfile.TemporaryFile()
对象,出于安全原因在未链接状态下创建;该文件存在,但目录条目在创建时立即被清除。因此,您无法从 ZODB 进程外部查看此文件。
完整提交会将数据移动到实际的 ZODB 数据库中并完成事务。
关于python - ZODB:transaction.savepoint 向哪里写入数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19710941/
我有这个代码 var myChart = new FusionCharts("../themes/clean/charts/hbullet.swf", "myChartId", "400", "75
既然写入是立即进行的(复制到内核缓冲区并返回),那么使用 io_submit 进行写入有什么好处? 事实上,它 (aio/io_submit) 看起来更糟,因为您必须在堆上分配写入缓冲区并且不能使用基
我正在使用 mootool 的 Request.JSON 从 Twitter 检索推文。收到它后,我将写入目标 div 的 .innerHTML 属性。当我在本地将其作为文件进行测试时,即 file:
最终,我想将 Vertica DB 中的数据抓取到 Spark 中,训练机器学习模型,进行预测,并将这些预测存储到另一个 Vertica DB 中。 当前的问题是确定流程最后部分的瓶颈:将 Spark
我使用 WEKA 库编写了一个 Java 程序, 训练分类算法 使用经过训练的算法对未标记的数据集运行预测 将结果写入 .csv 文件 问题在于它当前写出离散分类结果(即算法猜测一行属于哪个类别)。我
背景 - 我正在考虑使用 clickonce 通过 clickonce(通过网站)部署 WinForms 应用程序。相对简单的应用程序的要素是: - 它是一个可执行文件和一个数据库文件(sqlite)
是否有更好的解决方案来快速初始化 C 数组(在堆上创建)?就像我们使用大括号一样 double** matrix_multiply(const double **l_matrix, const dou
我正在读取 JSON 文件,取出值并进行一些更改。 基本上我向数组添加了一些值。之后我想将其写回到文件中。当我将 JSONArray 写回文件时,会被写入字符串而不是 JSONArray 对象。怎样才
我为两个应用程序使用嵌入式数据库,其中一个是服务器,另一个是客户端。客户端应用程序。可以向服务器端发送获取数据请求以检索数据并显示在表格(或其他)中。问题是这样的:如何将获取的数据保存(写入)到页面文
是否有更好的解决方案来快速初始化 C 数组(在堆上创建)?就像我们使用大括号一样 double** matrix_multiply(const double **l_matrix, const dou
从问题得出问题:找到所有 result = new ArrayList(); for (int i = 2; i >(i%8) & 0x1) == 0) { result.add(i
由于某种原因,它没有写入 CSV。谁能明白为什么它不写吗? def main(): list_of_emails = read_email_csv() #read input file, cr
关闭。 这个问题是 not reproducible or was caused by typos 。它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能在这里出现,
我目前正在开发一个保存和加载程序,但我无法获得正确的结果。 编写程序: #include #include #define FILENAME "Save" #define COUNT 6 type
import java.io.*; public class Main2 { public static void main(String[] args) throws Exception {
我需要使用预定义位置字符串“Office”从所有日历中检索所有 iOS 事件,然后将结果写入 NSLog 和 UITextView。 到目前为止,这是我的代码: #import "ViewCo
我正在尝试将 BOOL 值写入 PFInstallation 中的列,但会不停地崩溃: - (IBAction)pushSwitch:(id)sender { NSUserDefaults *push
我以前在学校学过一些简单的数据库编程,但现在我正在尝试学习最佳实践,因为我正在编写更复杂的应用程序。写入 MySQL 数据库并不难,但我想知道让分布式应用程序写入 Amazon EC2 上的远程数据库
是否可以写回到ResourceBundle?目前我正在使用 ResourceBundle 来存储信息,在运行时使用以下内容读取信息 while(ResourceBundle.getBundle("bu
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我是一名优秀的程序员,十分优秀!