Ответы:
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
SELECT * FROM information_schema.columns
WHERE table_schema = DATABASE()
ORDER BY table_name, ordinal_position
Поскольку у меня недостаточно репутации, чтобы комментировать, вот небольшое улучшение (на мой взгляд) превосходного ответа Ника Райлза: замена 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;
Вопрос был:
Есть ли быстрый способ получить все имена столбцов из всех таблиц в 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
Я написал эту глупую вещь давным-давно и до сих пор фактически использую ее:
https://gist.github.com/kphretiq/e2f924416a326895233d
По сути, он выполняет «SHOW TABLES», затем «DESCRIBE» в каждой таблице, а затем выплевывает его в виде уценки.
Просто отредактируйте под "если имя » и вперед. Вам нужно будет установить pymysql.
Воспроизведение ответа Никола с некоторым читаемым 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>";