有谁知道一种方法来检测 Microsoft Access 表上次更改(插入或更新)的时间?我们通过 ADO COM 使用 OLEDB 以编程方式与访问数据库进行通信,并正在寻找一种检测特定表更改的方法。我们不需要知道这些变化是什么,只需要知道这些变化已经发生了。
4 回答
检测表中的数据是否已更改的唯一方法是对表执行查询。
您必须在表中添加一个类型列,DATETIME
例如命名LastUpdatedDate
的,表示每行的最后更新日期/时间。这样做,NOT NULL
以便您必须DATETIME
为每个INSERT
或写入该列的更新值UPDATE
。此外,将该列设置DATE()
为当前日期戳或NOW()
当前日期/时间戳的默认值。然后添加一个验证规则或CHECK
约束,例如CHECK (LastUpdatedDate = NOW())
确保列在每个UPDATE
and上实际更新INSERT
。
最后,运行一个MAX(LastUpdatedDate)
查询,你会得到你需要的。
每次访问表时都没有“手动”写入列的方法。
正如其他人所指出的,如果不自己编码,就无法跟踪更改。
ACC2000 上有一个简单的示例:如何在表单中创建记录更改的审计跟踪 http://support.microsoft.com/default.aspx?scid=kb;en-us;Q197592
审计跟踪 - 在记录级别记录更改:http: //allenbrowne.com/AppAudit.html 本文介绍了表单和子表单的编辑、插入和删除。
模块:维护更改历史 http://www.mvps.org/access/modules/mdl0021.htm History Table 例程旨在编写跟踪对一个或多个表中的字段所做的更改的历史记录。
您需要在表中实现时间戳列,并在数据更改期间更新值。