在MySQL中,我知道我可以在数据库中列出表:

SHOW TABLES

但是,我想将这些表名插入到另一个表中,例如:

INSERT INTO metadata(table_name) SHOW TABLES /* does not work */

是否有一种方法可以使用标准的SELECT语句来获取表名,比如:

INSERT INTO metadata(table_name) SELECT name FROM table_names /* what should table_names be? */

当前回答

除了使用INFORMATION_SCHEMA表外,要使用SHOW TABLES插入到表中,还需要使用以下命令

<?php
 $sql = "SHOW TABLES FROM $dbname";
 $result = mysql_query($sql);
 $arrayCount = 0
 while ($row = mysql_fetch_row($result)) {
  $tableNames[$arrayCount] = $row[0];
  $arrayCount++; //only do this to make sure it starts at index 0
 }
 foreach ($tableNames as &$name {
  $query = "INSERT INTO metadata (table_name) VALUES ('".$name."')";
  mysql_query($query);
 }
?>

其他回答

Try:

select * from information_schema.tables

参见:http://dev.mysql.com/doc/refman/5.0/en/information-schema.html

是的,使用information_schema.TABLES。 这甚至适用于如下所示的Skyvia这样的云解决方案:

有了它,您可以简单地使用像上面这样的SELECT语句将其添加到INSERT语句中。但是更改table_schema值以匹配实际设置的数据库名称。

我认为您可以从INFORMATION_SCHEMA TABLES中获得所需的数据。

你可以在这里找到更多信息:http://dev.mysql.com/doc/refman/5.0/en/tables-table.html

还有一种更简单的方法来获取表名

SHOW TABLES FROM <database_name>

如果我们有多个数据库,并且我们需要为一个特定的数据库选择所有的表,我们可以使用TABLE_SCHEMA定义数据库名称为:

从information_schema中选择table_name。where TABLE_SCHEMA='dbname';