有没有一种快速的方法可以从 中的所有表中获取所有列名MySQL
,而不必列出所有表?
11 回答
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
列出 MySQL 表中的所有字段:
select *
from information_schema.columns
where table_schema = 'your_DB_name'
and table_name = 'Your_tablename'
最好使用以下查询轻松获取所有列名
Show columns from tablename
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()
.
如果它对其他人有用,这将为您提供每个表中以逗号分隔的列列表:
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限制,这可能会导致数据被截断。
<?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>';
?>
与@suganya 发布的答案类似,这并不直接回答问题,但对于单个表来说是一种更快的替代方案:
DESCRIBE column_name;
问题是:
有没有一种快速的方法可以从 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
我很久以前写过这个愚蠢的东西,现在仍然不时使用它:
https://gist.github.com/kphretiq/e2f924416a326895233d
基本上,它会执行“SHOW TABLES”,然后在每个表上执行“DESCRIBE”,然后将其作为降价输出。
只需在“if name ”下方编辑即可。您需要安装 pymysql。
用一些可读的 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>";
您可以使用此查询查询特定数据库中每个表的所有列
select
TABLE_SCHEMA,
TABLE_NAME,
COLUMN_NAME
from
information_schema.columns
where
table_schema = 'database_name'
order by
table_name,
ordinal_position;