打印出最近添加的25个表

时间:2009-08-04 23:46:43

标签: php mysql

在下面的代码中,我允许用户将表添加到MySQL数据库。有没有办法打印出最近添加的25个表?

提前致谢,

约翰

$table = mysql_real_escape_string($_POST['name']);

$query = "CREATE TABLE `$table` (id INT(11) NOT NULL auto_increment, site VARCHAR(350) NOT NULL, cat1 BIGINT(9) NOT NULL, cat2 BIGINT(9) NOT NULL, PRIMARY KEY(id), UNIQUE (site))";
$result = mysql_query($query) or die(mysql_error());

2 个答案:

答案 0 :(得分:3)

select TABLE_NAME
  from INFORMATION_SCHEMA.TABLES
 where TABLE_SCHEMA='your_db_name`
 order by CREATE_TIME desc
 limit 25

这适用于MySQL 5及更高版本。它会列出用户创建的表格。

答案 1 :(得分:1)

您可以但我建议创建所有表创建(以及其他相关活动)的历史记录或审计表。例如:

$now = time();
$user = $_SESSION['user'];
$sql = <<<END
INSERT INTO table_history
(table, user, action, action_time)
VALUES
('$table', '$user', 'CREATE', $now)
END;
mysql_query($sql) or die($sql . ': ' . mysql_error());

另外,我可能建议不要为每个需要使用它的实例创建一个单独的表,除非它们真的很大。创建另一列以识别用户,组织或其他任何通常(但并非总是)更好的方法。