在我的页脚,我想添加一些东西,如“上次更新xx/xx/200x”,这个日期是最后一次某个mySQL表已更新。

最好的方法是什么?是否有检索最近更新日期的函数?每次需要这个值时,我都应该访问数据库吗?


当前回答

我会创建一个触发器,捕捉所有更新/插入/删除,并在自定义表中写入时间戳,类似于 表名|时间戳

只是因为我不喜欢直接读取db服务器的内部系统表的想法

其他回答

当查询不可用时,将查询缓存在全局变量中。

创建一个网页,在更新缓存时强制重新加载缓存。

将对重新加载页面的调用添加到部署脚本中。

操作系统级别分析:

查找DB在磁盘上的存储位置:

grep datadir /etc/my.cnf
datadir=/var/lib/mysql

检查最近的修改

cd /var/lib/mysql/{db_name}
ls -lrt

应该适用于所有数据库类型。

在MySQL的新版本中,你可以使用information_schema数据库来告诉你什么时候另一个表被更新了:

SELECT UPDATE_TIME
FROM   information_schema.tables
WHERE  TABLE_SCHEMA = 'dbname'
   AND TABLE_NAME = 'tabname'

这当然意味着打开到数据库的连接。


另一种选择是每当MySQL表更新时“触摸”一个特定的文件:

数据库更新:

以O_RDRW模式打开时间戳文件 再次关闭

或者

使用touch(),相当于PHP中的utimes()函数,来更改文件时间戳。

页面显示:

使用stat()读取文件修改时间。

如果您正在运行Linux,您可以使用inotify来查看表或数据库目录。inotify可以从PHP, node.js, perl和大多数其他语言中获得。当然,你必须安装inotify或让你的ISP安装它。很多ISP不会这么做。

不知道你会不会对这个感兴趣。在mysql和客户端之间使用mysqlproxy,并使用lua脚本根据有趣的表变化更新memcached中的键值update,DELETE,INSERT是我最近做的解决方案。如果包装器支持php中的钩子或触发器,这可能会更容易。到目前为止,没有一个包装器这样做。