227

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

4

11 回答 11

367
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
于 2011-04-13T11:50:32.523 回答
53

列出 MySQL 表中的所有字段:

select * 
  from information_schema.columns 
 where table_schema = 'your_DB_name' 
   and table_name = 'Your_tablename'
于 2012-11-22T05:49:06.020 回答
39

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

Show columns from tablename

于 2016-07-16T12:55:12.773 回答
29
SELECT * FROM information_schema.columns
WHERE table_schema = DATABASE()
ORDER BY table_name, ordinal_position

由于我没有足够的代表发表评论,因此(在我看来)对 nick rulez 的出色答案有一个小的改进:替换WHERE table_schema = 'your_db'WHERE table_schema = DATABASE().

于 2015-06-10T13:56:46.323 回答
21

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

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

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

于 2015-12-22T17:11:39.790 回答
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>';
?>
于 2013-01-29T10:48:41.167 回答
5

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

DESCRIBE column_name;
于 2017-01-26T19:10:33.920 回答
5

问题是:

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

SQL 获取每列的所有信息

select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position

SQL 获取所有列名

select COLUMN_NAME from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
于 2018-01-26T13:33:31.853 回答
3

我很久以前写过这个愚蠢的东西,现在仍然不时使用它:

https://gist.github.com/kphretiq/e2f924416a326895233d

基本上,它会执行“SHOW TABLES”,然后在每个表上执行“DESCRIBE”,然后将其作为降价输出。

只需在“if name ”下方编辑即可。您需要安装 pymysql。

于 2015-11-30T20:32:27.917 回答
3

用一些可读的 php 捎带 Nicola 的回答

$a = mysqli_query($conn,"select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position");
$b = mysqli_fetch_all($a,MYSQLI_ASSOC);
$d = array();
foreach($b as $c){
    if(!is_array($d[$c['TABLE_NAME']])){
        $d[$c['TABLE_NAME']] = array();
    }
    $d[$c['TABLE_NAME']][] = $c['COLUMN_NAME'];
}
echo "<pre>",print_r($d),"</pre>";
于 2016-10-14T02:14:25.750 回答
2

您可以使用此查询查询特定数据库中每个表的所有列

select
    TABLE_SCHEMA,
    TABLE_NAME,
    COLUMN_NAME
from
    information_schema.columns
where
    table_schema = 'database_name'
order by 
    table_name,
    ordinal_position;
于 2021-06-24T08:04:50.310 回答