Получить имена столбцов таблицы в MySQL?

301

Есть ли способ получить имя столбца таблицы в MySQL? используя php

Сотрудник
источник

Ответы:

537

Вы можете использовать DESCRIBE :

DESCRIBE my_table;

Или в более новых версиях вы можете использовать INFORMATION_SCHEMA :

SELECT COLUMN_NAME
  FROM INFORMATION_SCHEMA.COLUMNS
  WHERE TABLE_SCHEMA = 'my_database' AND TABLE_NAME = 'my_table';

Или вы можете использовать SHOW COLUMNS :

SHOW COLUMNS FROM my_table;
Greg
источник
14
DESCRIBE - это ярлык SHOW COLUMNS ( dev.mysql.com/doc/refman/5.0/en/describe.html )
svens,
11
Я бы проголосовал за версию Information_Schema, так как этот синтаксис поддерживается большинством основных баз данных. Лучше всего учиться только 1 способ, если нужно.
Кибби
3
+1 Я хотел выбрать имена таблиц, где существует столбец, я сделалSELECT TABLE_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = 'db_name' AND COLUMN_NAME = 'col_name';
AL̲̳I
2
сохраняйте байты с помощью desc my_table;:-)
Альфонсо Перес
3
DESCдля описания можно легко спутать с DESCнисходящим. Номинальное количество байтов, которое вы сохраняете из-за отсутствия читабельности, не стоит.
Жак Матье
34

Следующие операторы SQL почти эквивалентны:

SELECT COLUMN_NAME
  FROM INFORMATION_SCHEMA.COLUMNS
 WHERE table_name = 'tbl_name'
  [AND table_schema = 'db_name']
  [AND column_name LIKE 'wild']

SHOW COLUMNS
FROM tbl_name
[FROM db_name]
[LIKE 'wild']

Ссылка: INFORMATION_SCHEMA COLUMNS

OMG пони
источник
1
Почему вы говорите «почти»?
Pacerier
2
@Pacerier Во-первых, второй не будет работать как подзапрос.
WAF
@ ВАФ, я думаю, что он имел в виду совсем другое, не это.
Pacerier
2
В моем быстром тесте SHOW COLUMNSвозвращает таблицу, содержащую имена столбцов, типы и т. Д., А SELECT COLUMN NAMEвозвращает только имена столбцов.
mwfearnley
20

Я сделал функцию PDO, которая возвращает все имена столбцов в простом массиве.

public function getColumnNames($table){
    $sql = "SELECT COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = :table";
    try {
        $core = Core::getInstance();
        $stmt = $core->dbh->prepare($sql);
        $stmt->bindValue(':table', $table, PDO::PARAM_STR);
        $stmt->execute();
        $output = array();
        while($row = $stmt->fetch(PDO::FETCH_ASSOC)){
            $output[] = $row['COLUMN_NAME'];                
        }
        return $output; 
    }

    catch(PDOException $pe) {
        trigger_error('Could not connect to MySQL database. ' . $pe->getMessage() , E_USER_ERROR);
    }
}

На выходе будет массив:

Array (
[0] => id
[1] => name
[2] => email
[3] => shoe_size
[4] => likes
... )

Извините за некро, но мне нравится моя функция;)

PS Я не включил класс Core, но вы можете использовать свой собственный класс .. DS

Филипп
источник
Что с прописным фетишем?
Pacerier
Нет ничего плохого в ответе на старый вопрос о переполнении стека.
bdsl
1
Спасибо. Для вывода я использовал этот способ: $ columns = $ stmt-> fetchAll (\ PDO :: FETCH_ASSOC); return array_column ($ columns, 'COLUMN_NAME');
Ehsan
6

Это решение из командной строки mysql

mysql>USE information_schema;

В приведенном ниже запросе просто измените <- DATABASE_NAME -> на вашу базу данных, а <- TABLENAME -> на имя таблицы, где вы просто хотите указать значения полей оператора DESCRIBE.

mysql> SELECT COLUMN_NAME FROM COLUMNS WHERE TABLE_SCHEMA = '<--DATABASE_NAME-->' AND   TABLE_NAME='<--TABLENAME-->';
лила
источник
4

Там также это, если вы предпочитаете:

mysql_query('SHOW COLUMNS FROM tableName'); 
Джеймс Гудвин
источник
4

Как насчет этого:

SELECT @cCommand := GROUP_CONCAT( COLUMN_NAME ORDER BY column_name SEPARATOR ',\n')
FROM INFORMATION_SCHEMA.COLUMNS 
WHERE TABLE_SCHEMA = 'my_database' AND TABLE_NAME = 'my_table';

SET @cCommand = CONCAT( 'SELECT ', @cCommand, ' from my_database.my_table;');
PREPARE xCommand from @cCommand;
EXECUTE xCommand;
Волк метцнер
источник
4

Также интересно отметить, что вы можете использовать
EXPLAIN table_nameсиноним DESCRIBE table_nameи, SHOW COLUMNS FROM table_name хотя EXPLAIN чаще используется для получения информации о плане выполнения запроса.

Anthonys
источник
3

Смотреть в:

mysql_query('DESCRIBE '.$table);
Энди Хьюм
источник
3

Таблица описания функции MySQL должна привести вас туда, куда вы хотите пойти (укажите название таблицы как «таблица»). Тебе придется немного разобрать вывод, но это довольно просто. Насколько я помню, если вы выполните этот запрос, в результате запроса PHP, получающего доступ к функциям, которые обычно дают вам пару ключ-значение, в качестве ключей будут использоваться имена столбцов. Но прошло уже много времени с тех пор, как я использовал PHP, поэтому не удерживайте меня на этом. :)

dannysauer
источник
Есть несколько довольно хороших документов на php.net в us3.php.net/manual/en/function.mysql-list-fields.php
dannysauer
3

Вы также можете проверить mysql_fetch_array(), как в:

$rs = mysql_query($sql);
while ($row = mysql_fetch_array($rs)) {
//$row[0] = 'First Field';
//$row['first_field'] = 'First Field';
}
thewebguy
источник
3

Мне нужны были имена столбцов в виде плоского массива, в то время как другие ответы возвращали ассоциативные массивы, поэтому я использовал:

$con = mysqli_connect('localhost',$db_user,$db_pw,$db_name);
$table = 'people';

/**
* Get the column names for a mysql table
**/

function get_column_names($con, $table) {
  $sql = 'DESCRIBE '.$table;
  $result = mysqli_query($con, $sql);

  $rows = array();
  while($row = mysqli_fetch_assoc($result)) {
    $rows[] = $row['Field'];
  }

  return $rows;
}

$col_names = function get_column_names($con, $table);

$ col_names теперь равно:

(
    [0] => name
    [1] => parent
    [2] => number
    [3] => chart_id
    [4] => type
    [5] => id
)
duhaime
источник
2

mysql_list_fieldsФункция может заинтересовать вас; но, как говорится в руководстве:

Эта функция устарела. Предпочтительно использовать mysql_query()для выдачи оператора SQL SHOW COLUMNS FROM table [LIKE 'name']вместо.

Паскаль МАРТИН
источник
Как работает функция, если она не выдает SQL-запрос к серверу? Почему это устарело?
Pacerier
2

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

DESC TableName

или вы можете использовать следующий запрос.

SHOW COLUMNS FROM TableName
Хариш Кумар
источник
2

в MySQL, чтобы получить детали столбцов и структуру таблицы, следуя ключевым словам или запросам

1.DESC table_name

2.DESCRIBE table_name

3.SHOW COLUMNS FROM table_name

4.SHOW create table table_name;

5.EXPLAIN table_name

денис
источник
2
$col = $db->query("SHOW COLUMNS FROM category");

while ($fildss = $col->fetch_array())
{             
    $filds[] = '"{'.$fildss['Field'].'}"';
    $values[] = '$rows->'.$fildss['Field'].'';
}

if($type == 'value')
{
    return $values = implode(',', $values);
}
else {
     return $filds = implode(',', $filds);
}
ibRQD
источник
1
Чтобы быть более полезными для будущих пользователей, не могли бы вы предоставить некоторый контекст для своего ответа, а не просто дамп кода.
Пол Захра
1

это сработало для меня ..

$sql = "desc MyTableName";
$result = @mysql_query($sql);
while($row = @mysql_fetch_array($result)){
    echo $row[0]."<br>";
}
Ad Kahn
источник
1

Я написал простой скрипт php для извлечения столбцов таблицы через PHP: Show_table_columns.php

<?php
$db = 'Database'; //Database name
$host = 'Database_host'; //Hostname or Server ip
$user = 'USER'; //Database user
$pass = 'Password'; //Database user password
$con = mysql_connect($host, $user, $pass);
if ($con) {
    $link = mysql_select_db($db) or die("no database") . mysql_error();
    $count = 0;
    if ($link) {
        $sql = "
            SELECT column_name
            FROM   information_schema.columns
            WHERE  table_schema = '$db'
                   AND table_name = 'table_name'"; // Change the table_name your own table name
        $result = mysql_query($sql, $con);
        if (mysql_query($sql, $con)) {
            echo $sql . "<br> <br>";
            while ($row = mysql_fetch_row($result)) {
                echo "COLUMN " . ++$count . ": {$row[0]}<br>";
                $table_name = $row[0];
            }
            echo "<br>Total No. of COLUMNS: " . $count;
        } else {
            echo "Error in query.";
        }
    } else {
        echo "Database not found.";
    }
} else {
    echo "Connection Failed.";
}
?>

Наслаждайтесь!

Хусснейн шейх
источник
1
Пожалуйста,
опубликуйте
0

mysqli fetch_field () работал для меня:

if ($result = $mysqli -> query($sql)) {
  // Get field information for all fields
  while ($fieldinfo = $result -> fetch_field()) {
    printf("Name: %s\n", $fieldinfo -> name);
    printf("Table: %s\n", $fieldinfo -> table);
    printf("Max. Len: %d\n", $fieldinfo -> max_length);
  }
  $result -> free_result();
}

Источник: https://www.w3schools.com/pHP/func_mysqli_fetch_field.asp

Дэвид М
источник