Antworten:
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
Es ist besser, wenn Sie die folgende Abfrage verwenden, um alle Spaltennamen einfach abzurufen
Show columns from tablename
SELECT * FROM information_schema.columns
WHERE table_schema = DATABASE()
ORDER BY table_name, ordinal_position
Da ich nicht genug Repräsentanten habe, um Kommentare abzugeben, ist hier (meiner Ansicht nach) eine geringfügige Verbesserung gegenüber der hervorragenden Antwort von Nick Rulez: Ersetzen WHERE table_schema = 'your_db'
durch WHERE table_schema = DATABASE()
.
Wenn dies für andere nützlich ist, erhalten Sie eine durch Kommas getrennte Liste der Spalten in jeder Tabelle:
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
Hinweis: Wenn Sie Tabellen mit einer hohen Anzahl von Spalten und / oder langen Feldnamen verwenden, beachten Sie das Limit group_concat_max_len , das dazu führen kann, dass die Daten abgeschnitten werden.
<?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>';
?>
Ähnlich wie bei der Antwort von @suganya beantwortet dies die Frage nicht direkt, ist jedoch eine schnellere Alternative für eine einzelne Tabelle:
DESCRIBE column_name;
Die Frage war:
Gibt es eine schnelle Möglichkeit, alle SPALTENNAMEN aus allen Tabellen in MySQL abzurufen, ohne alle Tabellen auflisten zu müssen?
SQL, um alle Informationen für jede Spalte abzurufen
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
SQL, um alle SPALTENNAMEN zu erhalten
select COLUMN_NAME from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
Ich habe dieses dumme Ding vor langer Zeit geschrieben und benutze es immer noch ab und zu:
https://gist.github.com/kphretiq/e2f924416a326895233d
Grundsätzlich führt es eine "SHOW TABLES", dann eine "DESCRIBE" für jede Tabelle aus und spuckt sie dann als Markdown aus.
Bearbeiten Sie einfach unter dem "Wenn- Namen " und gehen Sie. Sie müssen pymysql installiert haben.
Huckepack auf Nicolas Antwort mit etwas lesbarem 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>";