簡體   English   中英

打印出25個最近添加的表

[英]Printing out 25 most recently added tables

在下面的代碼中,我允許用戶將表添加到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());
select TABLE_NAME
  from INFORMATION_SCHEMA.TABLES
 where TABLE_SCHEMA='your_db_name`
 order by CREATE_TIME desc
 limit 25

這適用於MySQL 5及更高版本。 不過,它將列出您的用戶您創建的表。

您可以,但我建議您為所有表創建(和其他相關活動)創建歷史記錄或審計表。 例如:

$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());

另外,我可能建議不要為需要使用它的每個實例創建單獨的表,除非它們真的很大。 創建另一列來標識用戶,組織或其他通常(但並非總是)更好的方法。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM