- Запрос MySQL для получения имен столбцов таблицы
- Ответ 1
- Ответ 2
- Ответ 3
- Ответ 4
- Ответ 5
- Ответ 6
- Ответ 7
- mysql_list_fields
- Описание
- Список параметров
- Возвращаемые значения
- Примеры
- Примечания
- Смотрите также
- User Contributed Notes 7 notes
- mysql_list_fields
- Описание
- Список параметров
- Возвращаемые значения
- Примеры
- Примечания
- Смотрите также
Запрос MySQL для получения имен столбцов таблицы
Я хотел бы получить все имена столбцов таблицы mysql в массив на php.
Есть ли для этого запрос?
Ответ 1
Лучше всего использовать виртуальную базу данных метаданных INFORMATION_SCHEMA . В частности, таблица INFORMATION_SCHEMA.COLUMNS .
SELECT `COLUMN_NAME`
FROM `INFORMATION_SCHEMA`.`COLUMNS`
WHERE `TABLE_SCHEMA`=’yourdatabasename’
AND `TABLE_NAME`=’yourtablename’;
Это ОЧЕНЬ мощный способ , и он может предоставить вам ТОННЫ информации без необходимости анализировать текст (например, тип столбца, наличие в нем значения NULL, максимальный размер столбца, набор символов и т. д.).
И это стандартный SQL (в то время как SHOW — это расширение для MySQL) .
Для получения дополнительной информации о различиях между таблицами SHOW. и их использовании с INFORMATION_SCHEMA, ознакомьтесь с общей документацией INFORMATION_SCHEMA для MySQL.
Ответ 2
Вы можете использовать следующий запрос для MYSQL:
SHOW `columns` FROM `your-table`;
Ниже приведен пример кода, который показывает, как реализовать указанный выше синтаксис в php для перечисления имен столбцов:
$sql = «SHOW COLUMNS FROM your-table»;
$result = mysqli_query($conn,$sql);
while($row = mysqli_fetch_array($result))
echo $row[‘Field’].»
«;
>
Для получения подробной информации о выводе SHOW COLUMNS FROM TABLE ознакомьтесь с документацией.
Ответ 3
Используйте mysql_fetch_field() для просмотра всех данных столбца. См. Руководство .
$query = ‘select * from myfield’;
$result = mysql_query($query);
$i = 0;
while ($i < mysql_num_fields($result))
$fld = mysql_fetch_field($result, $i);
$myarray[]=$fld->name;
$i = $i + 1;
>
«Предупреждение. Это расширение устарело с PHP 5.5.0 и будет удалено в будущем».
Ответ 4
Старая функция PHP «mysql_list_fields()» устарела. Сегодня лучший способ получить имена полей — это выполнить запрос « SHOW COLUMNS FROM table_name [LIKE ‘name’] ». Небольшой пример:
$fields = array();
$res=mysql_query(«SHOW COLUMNS FROM mytable»);
while ($x = mysql_fetch_assoc($res))
$fields[] = $x[‘Field’];
>
foreach ($fields as $f) < echo "
Field name: «.$f; >
Ответ 5
Если вы хотите проверить всю структуру таблицы с некоторыми полями, используйте этот код. В этом запросе я выбираю имя_столбца, тип_столбца и имя_таблицы для получения дополнительных сведений. Я использую order by column_type, чтобы легко это видеть.
SELECT `COLUMN_NAME`,COLUMN_TYPE,TABLE_NAME
FROM `INFORMATION_SCHEMA`.`COLUMNS`
WHERE `TABLE_SCHEMA`=’yourdatabasename’ order by DATA_TYPE;
Если вы хотите проверять только поля двойного типа, вы можете сделать это так :
SELECT `COLUMN_NAME`,COLUMN_TYPE,TABLE_NAME,DATA_TYPE
FROM `INFORMATION_SCHEMA`.`COLUMNS`
WHERE `TABLE_SCHEMA`=’yourdatabasename’ AND DATA_TYPE like ‘%bigint%’ order by DATA_TYPE;
Е сли вы хотите проверить, какое поле разрешает нулевой тип и т. д., можно использовать это:
SELECT `COLUMN_NAME`,COLUMN_TYPE,TABLE_NAME,IS_NULLABLE,DATA_TYPE
FROM `INFORMATION_SCHEMA`.`COLUMNS`
WHERE `TABLE_SCHEMA`=’yourdatabasename’ and DATA_TYPE like ‘%bigint%’ and IS_NULLABLE =’NO’ order by COLUMN_TYPE;
Ответ 6
Не уверен, что это то, что вы искали, но у меня это сработало:
$query = query(«DESC YourTable»);
$col_names = array_column($query, ‘Field’);
Этот код возвращает простой массив имен столбцов/имен переменных в вашей таблице или массиве в виде строк, что нужно для динамического построения запросов MySQL. Мое разочарование заключа ется в том, что я просто не знаю, как правильно индексировать массивы в PHP, поэтому я не уверен, что делать с результатами DESC или SHOW. Надеюсь, мой ответ будет полезен для таких новичков, как я!
Для получения результата:
print_r($col_names);
Ответ 7
- Пока первая строка вашей таблицы не содержит мегабайтного диапазона данных, она должна работать нормально.
- Имена функций db_rows и db_row_ar должны быть заменены вашей конкретной настройкой базы данных.
Мы будем очень благодарны
если под понравившемся материалом Вы нажмёте одну из кнопок социальных сетей и поделитесь с друзьями.
mysql_list_fields
Данная функция объявлена устаревшей в PHP 5.4.0, и, вместе с модулем MySQL, удалена PHP в 7.0.0. Вместо неё используйте активно развивающиеся модули MySQLi или PDO_MySQL. Так же смотрите раздел MySQL: выбор API. Альтернативы для этой функции:
Описание
mysql_list_fields ( string $database_name , string $table_name , resource $link_identifier = NULL ): resource
Возвращает информацию о таблице с переданным именем.
Эта функция устарела. Вместо неё рекомендуется использовать mysql_query() с SQL-запросом SHOW COLUMNS FROM table [LIKE ‘name’] .
Список параметров
Имя опрашиваемой базы данных.
Соединение MySQL. Если идентификатор соединения не был указан, используется последнее соединение, открытое mysql_connect() . Если такое соединение не было найдено, функция попытается создать таковое, как если бы mysql_connect() была вызвана без параметров. Если соединение не было найдено и не смогло быть создано, генерируется ошибка уровня E_WARNING .
Возвращаемые значения
Дескриптор результата ( resource ) в случае успешного выполнения, или false в случае возникновения ошибки.
Возвращаемый результат может быть обработан с помощью следующих функций: mysql_field_flags() , mysql_field_len() , mysql_field_name() и mysql_field_type() .
Примеры
Пример #1 Пример использования mysql_list_fields()
$result = mysql_query ( «SHOW COLUMNS FROM sometable» );
if (! $result ) echo ‘Ошибка при выполнении запроса: ‘ . mysql_error ();
exit;
>
if ( mysql_num_rows ( $result ) > 0 ) while ( $row = mysql_fetch_assoc ( $result )) print_r ( $row );
>
>
?>?php
Результатом выполнения данного примера будет что-то подобное:
Array ( [Field] => id [Type] => int(7) [Null] => Php mysql list all fields => PRI [Default] => [Extra] => auto_increment ) Array ( [Field] => email [Type] => varchar(100) [Null] => Php mysql list all fields => [Default] => [Extra] => )
Примечания
Замечание:
Для обратной совместимости может быть использован следующий устаревший псевдоним: mysql_listfields()
Смотрите также
- mysql_field_flags() — Возвращает флаги, связанные с указанным полем результата запроса
- mysql_info() — Возвращает информацию о последнем запросе
User Contributed Notes 7 notes
If you’re willing to use a lot of functions to get a little information about fields in a table, this function is for you. If you just want to get all the information you can find, you can use this:
// Taken from: http://ca.php.net/manual/en/function.mysql-field-flags.php
// Original by: amir at scrounch dot com
// Returns the name of the fields in the primary key for a table.
// Also keeps the fields in KEY order. Handy.
function getPrimaryKeyOf ( $table ) <
$keys = Array();
$query = sprintf ( «SHOW KEYS FROM `%s`» , $table );
$result = mysql_query ( $query ) or die( mysql_error ());
while ( $row = mysql_fetch_assoc ( $result )) if ( $row [ ‘Key_name’ ] == ‘PRIMARY’ )
$keys [ $row [ ‘Seq_in_index’ ] — 1 ] = $row [ ‘Column_name’ ];
>
// Returns a bunch of information about a table.
// The name of the auto-increment field, if any, fields in the
// primary key (using the function above), and all information
// about all fields.
function getTableInformationOf ( $table ) $information = array(
«auto» => «» ,
«primary» => array(),
«fields» => array()
);
$information [ ‘primary’ ] = $this -> getPrimaryKeyOf ( $table );
$result = mysql_query ( «DESC ` $table `» );
while ( $field = mysql_fetch_assoc ( $result ) ) $information [ ‘fields’ ][] = $field ;
if ( $field [ ‘Extra’ ] == «auto_increment» )
$information [ ‘auto’ ] = $field [ ‘Field’ ];
>
To make an array containing the names of a column from a table, you use the following simple script: (Note: using table1 with three columns)
$qColumnNames = mysql_query ( «SHOW COLUMNS FROM table1» , $db ) or die( «mysql error» );
$numColumns = mysql_num_rows ( $qColumnNames );
$x = 0 ;
while ( $x < $numColumns )
<
$colname = mysql_fetch_row ( $qColumnNames );
$col [ $colname [ 0 ]] = $colname [ 0 ];
$x ++;
>
/* it will have the following output
Array (
[firstcolumn] => firstcolumn
[secondcolumn] => secondcolumn
[thirdcolumn] => thirdcolumn
)
*/
?>
Or you can number the columns from zero. This help when using it in conjunction with mysql_fetch_row to get an array. You don’t have to remember which number of the array a certain column is.
$qColumnNames = mysql_query ( «SHOW COLUMNS FROM table1» , $db ) or die( «mysql error» );
$numColumns = mysql_num_rows ( $qColumnNames );
$x = 0 ;
while ( $x < $numColumns )
<
$colname = mysql_fetch_row ( $qColumnNames );
$col [ $colname [ 0 ]] = $x ;
$x ++;
>
/* it will have the following output
Array (
[firstcolumn] => 0
[secondcolumn] => 1
[thirdcolumn] => 2
)
*/
?>
To use it in conjuction with mysql_fetch_row:
$row = mysql_fetch_row ( «SELECT * from table1» , $db ) or die( «mysql error» );
?>
You can now call $row[col[firstcolumn]]. This becomes useful when you have a lot of columns.
Below script is used to get all coloumn indormation of an table.When we are working custome ORM then we need to match the coloumn name with array keys.
function getColoumn ( $table ) <
$result = mysql_query ( «SHOW COLUMNS FROM » . $table );
if (! $result ) <
echo ‘Could not run query: ‘ . mysql_error ();
>
$fieldnames =array();
if ( mysql_num_rows ( $result ) > 0 ) <
while ( $row = mysql_fetch_assoc ( $result )) <
$fieldnames [] = $row [ ‘Field’ ];
>
>
mysql_list_fields() retrieves information about the given table name but you can use something like mysql_fetch_field to retrieve the field names from a result source.
Every my html table output begins with heading row containing the field names. For that purpose I accepted the short combination of MySQL function, giving me a result similar to the mysql_fetch_array() for the row of values. The following example shows the basic idea. It should be adapted for the specific use:
//.
$field_names = array_keys ( mysql_fetch_array ( mysql_query ( $query , $link ), MYSQL_ASSOC ));
//.
?>
The advantage of this is, that it gives the names of the result, neither the field names of the whole table.
Please read the discussion about duplicate field names in SQL result carefully. The use, as shown in the example above, increments the pointer, hence some regular function, which does not, could be more useful 🙂
Note, using mysql_list_fields will change the currently selected database so subsequent mysql_query operations will be on the database in param 1 not the one selected with mysql_select_db
mysql_list_fields
This function was deprecated in PHP 5.4.0, and it and the entire original MySQL extension was removed in PHP 7.0.0. Instead, use either the actively developed MySQLi or PDO_MySQL extensions. See also the MySQL: choosing an API guide and its related FAQ entry for additional information. Alternatives to this function include:
Описание
resource mysql_list_fields ( string $database_name , string $table_name [, resource $link_identifier = NULL ] )
Возвращает информацию о таблице с переданным именем.
Эта функция устарела. Вместо нее рекомендуется использовать mysql_query() с SQL-запросом SHOW COLUMNS FROM table [LIKE ‘name’].
Список параметров
Имя опрашиваемой базы данных.
Соединение MySQL. Если идентификатор соединения не был указан, используется последнее соединение, открытое mysql_connect() . Если такое соединение не было найдено, функция попытается создать таковое, как если бы mysql_connect() была вызвана без параметров. Если соединение не было найдено и не смогло быть создано, генерируется ошибка уровня E_WARNING .
Возвращаемые значения
Дескриптор результата ( resource ) в случае успеха, или FALSE в случае ошибки.
Возвращаемый результат может быть обработан с помощью следующих функций: mysql_field_flags() , mysql_field_len() , mysql_field_name() и mysql_field_type() .
Примеры
Пример #1 Пример использования mysql_list_fields()
$result = mysql_query ( «SHOW COLUMNS FROM sometable» );
if (! $result ) echo ‘Ошибка при выполнении запроса: ‘ . mysql_error ();
exit;
>
if ( mysql_num_rows ( $result ) > 0 ) while ( $row = mysql_fetch_assoc ( $result )) print_r ( $row );
>
>
?>?php
Результатом выполнения данного примера будет что-то подобное:
Array ( [Field] => id [Type] => int(7) [Null] => Php mysql list all fields => PRI [Default] => [Extra] => auto_increment ) Array ( [Field] => email [Type] => varchar(100) [Null] => Php mysql list all fields => [Default] => [Extra] => )
Примечания
Замечание:
Для обратной совместимости может быть использован следующий устаревший псевдоним: mysql_listfields()
Смотрите также
- mysql_field_flags() — Возвращает флаги, связанные с указанным полем результата запроса
- mysql_info() — Возвращает информацию о последнем запросе