すべてのテーブルをリストすることなく、MySQL
のすべてのテーブルからすべての列名を取得する高速な方法はありますか?
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'
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()
に置き換える)に対する(私の見解では)マイナーな改善があります。
次のクエリを使用して、すべての列名を簡単に取得することをお勧めします
Show columns from tablename
それが他の誰にとっても有用であるという偶然に、これはあなたに各テーブルの列のコンマで区切られたリストを与えるでしょう:
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;
ニコラの答えを読みやすいphpでおんぶ
$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>";
私はずっと前にこのばかげたことを書きましたが、実際に時々それを実際に使用しています:
https://Gist.github.com/kphretiq/e2f924416a326895233d
基本的に、各テーブルで「SHOW TABLES」、次に「DESCRIBE」を実行し、マークダウンとして吐き出します。
「ifname」の下で編集して、行ってください。 pymysqlをインストールする必要があります。
問題は:
すべてのテーブルをリストすることなく、MySQLのすべてのテーブルからすべての列名を取得する高速な方法はありますか?
各列のすべての情報を取得する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