0

对于我的记录系统 (RDBMS) 中的给定表,我需要实现一个功能来逐步导出记录。例如,如果用户运行返回 x 条记录的导出作业,我想将快照 id 返回给用户。对于下一个导出作业,用户将该快照 ID 传递给我,并使用它我应该能够仅导出此后已修改或添加的记录。理想情况下,我希望我的快照 ID 可以重复使用。换句话说,我不希望我的快照 ID 过期,但这不是硬性要求。

鉴于我的所有表中都有 LAST_UPDATE_DATE (Timestamp) 列,解决此问题的最佳方法是什么?

我不是在寻找代码、工具或命令。我只是在寻找应该如何生成此快照 ID 并在后续调用中识别它以执行给定表中记录的增量导出的逻辑。

4

1 回答 1

1

时间戳显然是全局的,因此快照 ID 只需为单个时间戳。例如,在 SQL Server 中,您可以运行SELECT CURRENT_TIMESTAMP以获取当前时间戳。

当您要导出时,请在每个表上运行单独的查询以导出时间戳介于上次导出和当前导出之间的行。如果时间戳字段被索引,这些查询中的每一个都应该非常快,显然取决于要导出的数据量。

假设您在数据库上发生其他更新时运行这些导出,重要的是您只获取一次当前时间戳,将其存储为变量并使用该值(而不是CURRENT_TIMESTAMP自由使用),否则某些数据将丢失偶尔。

您可能需要考虑Deleted在每个表上都有一个列标志并更新它而不是删除行,这样您就知道哪些行被“删除”了。

于 2013-05-04T00:25:23.383 回答