怎样在mysql中获取列名
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎样在mysql中获取列名相关的知识,希望对你有一定的参考价值。
参考技术Ause 数据库名;
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中获取列名的主要内容,如果未能解决你的问题,请参考以下文章