Как получить имена всех столбцов для всех таблиц в MySQL? - PullRequest
163 голосов
/ 13 апреля 2011

Существует ли быстрый способ получения всех имен столбцов из всех таблиц в MySQL, без необходимости перечисления всех таблиц?

Ответы [ 10 ]

263 голосов
/ 13 апреля 2011
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
44 голосов
/ 22 ноября 2012

Чтобы вывести список всех полей из таблицы в MySQL:

select * 
  from information_schema.columns 
 where table_schema = 'your_DB_name' 
   and table_name = 'Your_tablename'
25 голосов
/ 10 июня 2015
SELECT * FROM information_schema.columns
WHERE table_schema = DATABASE()
ORDER BY table_name, ordinal_position

Поскольку у меня недостаточно представителей для комментариев, вот небольшое улучшение (на мой взгляд) по сравнению с отличным ответом Ника Реглеса: замена WHERE table_schema = 'your_db' на WHERE table_schema = DATABASE().

21 голосов
/ 16 июля 2016

лучше использовать следующий запрос, чтобы легко получить все имена столбцов

Show columns from tablename

17 голосов
/ 22 декабря 2015

В случае, если это полезно для всех остальных, это даст вам список столбцов в каждой таблице через запятую:

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 , которое может привести к усечению данных.

6 голосов
/ 29 января 2013
<code><?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 '
'; ?>
4 голосов
/ 26 января 2017

Аналогично ответу , опубликованному @ suganya , это не дает прямого ответа на вопрос, но является более быстрой альтернативой для одной таблицы:

DESCRIBE column_name;
3 голосов
/ 14 октября 2016

Воспроизведение ответа Никола с читаемым php

<code>$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),"
";
3 голосов
/ 30 ноября 2015

Я написал эту глупую вещь давным-давно и до сих пор действительно использую это время от времени:

https://gist.github.com/kphretiq/e2f924416a326895233d

По сути, он выполняет «ПОКАЗАТЬ ТАБЛИЦЫ», затем «ОПИСАТЬ» для каждой таблицы, а затем выплевывает его в виде уценки.

Просто отредактируйте под "if name " и начинайте. Вам нужно будет установить pymysql.

2 голосов
/ 26 января 2018

Вопрос был:

Существует ли быстрый способ получить все Имена столбцов из всех таблиц в MySQL без необходимости перечисления всех таблиц?1007 * 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
...