Odpowiedzi:
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
lepiej jest użyć następującego zapytania, aby łatwo uzyskać wszystkie nazwy kolumn
Show columns from tablename
SELECT * FROM information_schema.columns
WHERE table_schema = DATABASE()
ORDER BY table_name, ordinal_position
Ponieważ nie mam wystarczająco dużo rep do komentarza, tutaj jest poprawa drobne (moim zdaniem) na doskonałą odpowiedź nick rulez na: wymianie WHERE table_schema = 'your_db'
z WHERE table_schema = DATABASE()
.
Na szczęście przydaje się każdemu innemu, da ci rozdzieloną przecinkami listę kolumn w każdej tabeli:
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
Uwaga: Korzystając z tabel z dużą liczbą kolumn i / lub długimi nazwami pól, należy pamiętać o limicie group_concat_max_len , który może spowodować obcięcie danych.
<?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>';
?>
Podobnie do odpowiedzi wysłanej przez @suganya, to nie odpowiada bezpośrednio na pytanie, ale jest szybszą alternatywą dla pojedynczego stołu:
DESCRIBE column_name;
Pytanie brzmiało:
Czy istnieje szybki sposób na uzyskanie wszystkich NAZW KOLUMN ze wszystkich tabel w MySQL, bez konieczności wyświetlania wszystkich tabel?
SQL, aby uzyskać wszystkie informacje dla każdej kolumny
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
SQL, aby uzyskać wszystkie NAZWY KOLUMNOWE
select COLUMN_NAME from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
Dawno temu napisałem tę głupią rzecz i nadal używam jej od czasu do czasu:
https://gist.github.com/kphretiq/e2f924416a326895233d
Zasadniczo wykonuje „POKAŻ TABELE”, następnie „OPIS” na każdym stole, a następnie wyrzuca go jako markdown.
Po prostu edytuj poniżej „if name ” i idź. Musisz mieć zainstalowany pymysql.
Piggybacking na odpowiedzi Nicoli z czytelnym 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>";