有没有人知道一种方法来检测上次Microsoft Access表何时被更改(插入或更新)?我们通过ADO COM使用OLEDB以编程方式与访问数据库进行通信,并且正在寻找一种检测特定表的更改的方法。我们不需要知道这些变化是什么,只需要做出改变。
检测表中的数据是否已更改的唯一方法是对表执行查询。
您必须在表格中添加DATETIME
类型的列,例如命名为LastUpdatedDate
,表示每行的最后更新日期/时间。使它成为NOT NULL
,这样你就必须为每个DATETIME
或INSERT
写一个更新的UPDATE
值到该列。此外,将列设置为当前日期戳的默认值为DATE()
,或者为当前日期/时间戳设置NOW()
。然后添加验证规则或CHECK
约束,例如CHECK (LastUpdatedDate = NOW())
确保列在每个UPDATE
和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历史记录表例程旨在编写跟踪对一个或多个表中的字段所做更改的历史记录。
您需要在表中实现时间戳列,并在数据更改期间更新值。