在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? */

当前回答

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

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

其他回答

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

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

下面这个问题对我有用。这可以显示数据库,表,列名,数据类型和列数。

**select table_schema Schema_Name ,table_name TableName,column_name ColumnName,ordinal_position "Position",column_type DataType,COUNT(1) ColumnCount
FROM information_schema.columns
GROUP by table_schema,table_name,column_name,ordinal_position, column_type;**

Try:

select * from information_schema.tables

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

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

SHOW TABLES FROM <database_name>
SELECT table_name 
FROM information_schema.tables 
WHERE table_schema = 'DATABASE'