Упорядочить таблицы базы данных по времени создания
Привет, я хочу перечислить все свои таблицы из базы данных и упорядочить их по времени, как я могу сделать это до сих пор, я могу перечислить все свои таблицы из базы данных, но я не могу упорядочить их по времени;
$dbname = "album";
if (!mysql_connect("localhost", "root", "")) {
echo "Could not connect to mysql";
exit;
}
$sql = "SHOW TABLES FROM $dbname";
$result = mysql_query($sql);
if (!$result) {
echo "DB Error, could not list tables\n";
echo "MySQL Error: " . mysql_error();
exit;
}
$sorts = array();
while ($row = mysql_fetch_row($result)) {
echo "Table: {$row[0]}"."<br>";
}
mysql_free_result($result);
3 ответа
Решение
Это может быть решением
select * from information_schema.columns
order by create_time, column, table;
Это может помочь вам:
$sql = "
SELECT create_time, table_name
FROM information_schema.tables
WHERE table_schema = '$dbname'
ORDER BY create_time
";
Также измените внутреннюю часть while, как показано ниже:
while ($row = mysql_fetch_array($result)) {
echo "Table: {$row['table_name']} - {$row['create_time']} <br/>";
}
Используйте таблицы information_schema
select * from information_schema.columns
order by create_time, column_name, table_name;
Или, если вы хотите более узкий набор результатов:
select column_name, table_name, data_type, character_maximum_length,
is_nullable, column_default, create_time
from information_schema.columns
order by create_time, column_name, table_name;