如何获取MySQL中所有表的所有列的名称?

die*_*ter 173 mysql database-metadata database-schema

有没有快速的方法从所有表中获取所有列名MySQL,而不必列出所有表?

Nic*_*ssu 279

select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
Run Code Online (Sandbox Code Playgroud)


小智 46

要列出MySQL中表的所有字段:

select * 
  from information_schema.columns 
 where table_schema = 'your_DB_name' 
   and table_name = 'Your_tablename'
Run Code Online (Sandbox Code Playgroud)


小智 26

SELECT * FROM information_schema.columns
WHERE table_schema = DATABASE()
ORDER BY table_name, ordinal_position
Run Code Online (Sandbox Code Playgroud)

由于我没有足够的评论来评论,所以这是一个小改进(在我看来),而不是nick rulez的优秀答案:替换WHERE table_schema = 'your_db'WHERE table_schema = DATABASE().


小智 25

最好使用以下查询轻松获取所有列名

Show columns from tablename

  • 从命令得到类似的结果:DESCRIBE tablename; (3认同)

tra*_*hag 17

如果它对其他人有用,那么这将为您提供以逗号分隔的每个表中列的列表:

SELECT table_name,GROUP_CONCAT(column_name ORDER BY ordinal_position)
FROM information_schema.columns
WHERE table_schema = DATABASE()
GROUP BY table_name
ORDER BY table_name
Run Code Online (Sandbox Code Playgroud)

注意:使用具有大量列和/或长字段名称的表时,请注意group_concat_max_len限制,这可能导致数据被截断.


Ali*_*waz 6

<?php
        $table = 'orders';
        $query = "SHOW COLUMNS FROM $table";
        if($output = mysql_query($query)):
            $columns = array();
            while($result = mysql_fetch_assoc($output)):
                $columns[] = $result['Field'];
            endwhile;
        endif;
        echo '<pre>';
        print_r($columns);
        echo '</pre>';
?>
Run Code Online (Sandbox Code Playgroud)


Phi*_*ide 5

@suganya 发布答案类似,这并没有直接回答问题,但对于单个表来说是一个更快的替代方案:

DESCRIBE column_name;
Run Code Online (Sandbox Code Playgroud)


J.B*_*Mai 5

问题是:

有没有一种快速的方法可以从 MySQL 的所有表中获取所有列名,而不必列出所有表?

SQL获取每列的所有信息

select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
Run Code Online (Sandbox Code Playgroud)

获取所有列名的 SQL

select COLUMN_NAME from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
Run Code Online (Sandbox Code Playgroud)