在我的页脚,我想添加一些东西,如“上次更新xx/xx/200x”,这个日期是最后一次某个mySQL表已更新。
最好的方法是什么?是否有检索最近更新日期的函数?每次需要这个值时,我都应该访问数据库吗?
在我的页脚,我想添加一些东西,如“上次更新xx/xx/200x”,这个日期是最后一次某个mySQL表已更新。
最好的方法是什么?是否有检索最近更新日期的函数?每次需要这个值时,我都应该访问数据库吗?
当前回答
我让它在本地工作,但不是在我的公共网站的共享主机上(我想是配股问题)。
SELECT last_update FROM mysql.innodb_table_stats WHERE table_name = 'yourTblName';
'2020-10-09 08:25:10'
MySQL 5.7.20-log在win8.1上
其他回答
我会创建一个触发器,捕捉所有更新/插入/删除,并在自定义表中写入时间戳,类似于 表名|时间戳
只是因为我不喜欢直接读取db服务器的内部系统表的想法
这就是我所做的,希望能有所帮助。
<?php
mysql_connect("localhost", "USER", "PASSWORD") or die(mysql_error());
mysql_select_db("information_schema") or die(mysql_error());
$query1 = "SELECT `UPDATE_TIME` FROM `TABLES` WHERE
`TABLE_SCHEMA` LIKE 'DataBaseName' AND `TABLE_NAME` LIKE 'TableName'";
$result1 = mysql_query($query1) or die(mysql_error());
while($row = mysql_fetch_array($result1)) {
echo "<strong>1r tr.: </strong>".$row['UPDATE_TIME'];
}
?>
a)它会显示你所有的表和最近的更新日期
SHOW TABLE STATUS FROM db_name;
然后,你可以进一步询问具体的表格:
SHOW TABLE STATUS FROM db_name like 'table_name';
b)在上面的例子中,你不能在'Update_time'上使用排序,但是使用SELECT你可以:
SELECT * FROM information_schema.tables WHERE TABLE_SCHEMA='db_name' ORDER BY UPDATE_TIME DESC;
要进一步询问特定的表:
SELECT * FROM information_schema.tables WHERE TABLE_SCHEMA='db_name' AND table_name='table_name' ORDER BY UPDATE_TIME DESC';
最简单的方法是检查磁盘上表文件的时间戳。例如,您可以在数据目录下检查
cd /var/lib/mysql/<mydatabase>
ls -lhtr *.ibd
这将为您提供所有表的列表,其中的表是最后一次修改该表的时间、最早的时间。
我没有information_schema数据库,使用mysql版本4.1.16,所以在这种情况下,你可以查询这个:
SHOW TABLE STATUS FROM your_database LIKE 'your_table';
它将返回这些列:
| Name | Engine | Version | Row_format | Rows | Avg_row_length
| Data_length | Max_data_length | Index_length | Data_free | Auto_increment
| Create_time | Update_time | Check_time | Collation
| Checksum | Create_options | Comment |
如您所见,有一列名为“Update_time”,它显示了your_table的最后一次更新时间。