怎样在mysql中获取列名

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎样在mysql中获取列名相关的知识,希望对你有一定的参考价值。

参考技术A
use 数据库名;       
show tables;               //显示数据库中的表
desc 具体某个表的名称;    //列出想要的表的列名信息
//或者:show columns form 具体某个表的名称;

参考技术B 命令行执行
desc tablename ;
就输出列名及详细信息

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

【中文标题】如何获取 MySQL 中所有表的所有列名?【英文标题】:How to get all columns' names for all the tables in MySQL? 【发布时间】:2011-08-04 15:22:30 【问题描述】:

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

【问题讨论】:

我只需要快速浏览一下数据库。它不会是应用程序中的代码。 【参考方案1】:
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position

【讨论】:

那是我一直在寻找的 :-) 现在写了一个 java 应用程序做同样的事情 谢谢!要仅获取列名,请使用以下命令: select column_name from information_schema.columns where table_schema = 'your_db' order by table_name, ordinal_position 正是我想要的!谢谢。 如何获取列名前面填充数据的计数?我有同样的问题加上数据计数 知道主键怎么样?【参考方案2】:

列出 MySQL 表中的所有字段:

select * 
  from information_schema.columns 
 where table_schema = 'your_DB_name' 
   and table_name = 'Your_tablename'

【讨论】:

有趣 - 我在 'where 子句'中得到“未知列 'column_name'【参考方案3】:

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

Show columns from tablename

【讨论】:

有时你需要一个不依赖于information_schema的解决方案【参考方案4】:
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()

【讨论】:

这很有帮助。当可以避免时,硬编码这样的事情总是让我很恼火。谢谢。【参考方案5】:

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

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 限制,这可能会导致数据被截断。

【讨论】:

我喜欢这个...因为我可以轻松复制所有列名。【参考方案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>';
?>

【讨论】:

任何在 2016 年阅读本文的人 - mysql_query 已被弃用。以后最好使用 PHP 的 mysqli。【参考方案7】:

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

DESCRIBE column_name;

【讨论】:

这将打印一个表格,而不仅仅是表格的列名。【参考方案8】:

问题是:

有没有一种快速的方法可以从 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

【讨论】:

【参考方案9】:

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

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

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

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

【讨论】:

【参考方案10】:

用一些可读的 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>";

【讨论】:

'一些可读的 php'.. 用 a、b、c 命名变量不是我所说的可读【参考方案11】:

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

select
    TABLE_SCHEMA,
    TABLE_NAME,
    COLUMN_NAME
from
    information_schema.columns
where
    table_schema = 'database_name'
order by 
    table_name,
    ordinal_position;

【讨论】:

以上是关于怎样在mysql中获取列名的主要内容,如果未能解决你的问题,请参考以下文章

MYSQL中使用sql函数怎样截取字符串

怎样用VB.NET 2005在mysql数据库中创建一张表?

Oracle 怎样查询所有自增的序列名

mysql怎样将一张表里一列的数据更新到另一个表的一列上

怎样用c语言给mysql数据库插数据

DB2/SQL怎样把列名变为一列数据