- mysql_list_fields
- Описание
- Список параметров
- Возвращаемые значения
- Примеры
- Примечания
- Смотрите также
- User Contributed Notes 7 notes
- mysql_field_name
- Описание
- Список параметров
- Возвращаемые значения
- Примеры
- Примечания
- Смотрите также
- mysql_field_name
- Описание
- Список параметров
- Возвращаемые значения
- Примеры
- Примечания
- Смотрите также
- User Contributed Notes 12 notes
- search $database for $userquery, found match(es) in $myfield:
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 запрос название поля => PRI [Default] => [Extra] => auto_increment ) Array ( [Field] => email [Type] => varchar(100) [Null] => Php запрос название поля => [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_field_name
Данное расширение устарело, начиная с версии PHP 5.5.0, и будет удалено в будущем. Используйте вместо него MySQLi или PDO_MySQL. Смотрите также инструкцию MySQL: выбор API и соответствующий FAQ для получения более подробной информации. Альтернативы для данной функции:
Описание
mysql_field_name() возвращает название колонки с указанным индексом.
Список параметров
Обрабатываемый результат запроса. Этот результат может быть получен с помощью функции mysql_query() .
Числовое смещение поля. field_offset начинается с 0. Если field_offset не существует, генерируется ошибка уровня E_WARNING .
Возвращаемые значения
Название поля по указанному индексу в случае успеха или FALSE в случае возникновения ошибки.
Примеры
Пример #1 Пример использования mysql_field_name()
/* Таблица пользователей состоит из трёх колонок:
* user_id
* username
* password.
*/
$link = mysql_connect ( ‘localhost’ , ‘mysql_user’ , ‘mysql_password’ );
if (! $link ) die( ‘Ошибка соединения с MySQL: ‘ . mysql_error ());
>
$dbname = ‘mydb’ ;
$db_selected = mysql_select_db ( $dbname , $link );
if (! $db_selected ) die( «Не удалось выбрать базу $dbname : » . mysql_error ());
>
$res = mysql_query ( ‘select * from users’ , $link );
?php
echo mysql_field_name ( $res , 0 ) . «\n» ;
echo mysql_field_name ( $res , 2 );
?>
Результат выполнения данного примера:
Примечания
Замечание: Имена полей, возвращаемые этой функцией являются регистро-зависимыми.
Замечание:
Для обратной совместимости может быть использован следующий устаревший псевдоним: mysql_fieldname()
Смотрите также
- mysql_field_type() — Возвращает тип указанного поля из результата запроса
- mysql_field_len() — Возвращает длину указанного поля
mysql_field_name
Данный модуль устарел, начиная с версии PHP 5.5.0, и удалён в PHP 7.0.0. Используйте вместо него MySQLi или PDO_MySQL. Смотрите также инструкцию MySQL: выбор API. Альтернативы для данной функции:
Описание
mysql_field_name() возвращает название колонки с указанным индексом.
Список параметров
Обрабатываемый результат запроса. Этот результат может быть получен с помощью функции mysql_query() .
Числовое смещение поля. field_offset начинается с 0 . Если field_offset не существует, генерируется ошибка уровня E_WARNING .
Возвращаемые значения
Название поля по указанному индексу в случае успешного выполнения или false в случае возникновения ошибки.
Примеры
Пример #1 Пример использования mysql_field_name()
/* Таблица пользователей состоит из трёх колонок:
* user_id
* username
* password.
*/
$link = mysql_connect ( ‘localhost’ , ‘mysql_user’ , ‘mysql_password’ );
if (! $link ) die( ‘Ошибка соединения с MySQL: ‘ . mysql_error ());
>
$dbname = ‘mydb’ ;
$db_selected = mysql_select_db ( $dbname , $link );
if (! $db_selected ) die( «Не удалось выбрать базу $dbname : » . mysql_error ());
>
$res = mysql_query ( ‘select * from users’ , $link );
?php
echo mysql_field_name ( $res , 0 ) . «\n» ;
echo mysql_field_name ( $res , 2 );
?>
Результат выполнения данного примера:
Примечания
Замечание: Имена полей, возвращаемые этой функцией являются зависимыми от регистра.
Замечание:
Для обратной совместимости может быть использован следующий устаревший псевдоним: mysql_fieldname()
Смотрите также
- mysql_field_type() — Возвращает тип указанного поля из результата запроса
- mysql_field_len() — Возвращает длину указанного поля
User Contributed Notes 12 notes
This function is slightly stupid to be honest, why not just make an array of field names. You could consolidate the two of these functions that way and it makes it a lot easier to list them when your script is dynamic.
function mysql_field_array ( $query )
$field = mysql_num_fields ( $query );
$names [] = mysql_field_name ( $query , $i );
$fields = mysql_field_array ( $query );
echo implode ( ‘, ‘ , $fields [ 3 ] );
// Count them — easy equivelant to ‘mysql_num_fields’
This is another variant of displaying all columns of a query result, but with a simplified while loop.
$query=»select * from user»;
$result=mysql_query($query);
$numfields = mysql_num_fields($result);
while ($row = mysql_fetch_row($result)) // Data
< echo '
\n»; >
here’s one way to print out a row of
NOTE: i didn’t test this
$result = mysql_query(«select * from table»);
post a comment if there’s an error
james, why make so difficult when it’s very simple :\
for ($i=0; $i $var = mysql_field_name($res_gb, $i);
$row_title .= $var;
>
The code in the last comment has an obvious mistake in the for loop expression. The correct expression in the for-loop is $x $y>
$result = mysql_query($sql,$conn) or die(mysql_error());
$rowcount=mysql_num_rows($result);
$y=mysql_num_fields($result);
for ($x=0; $x echo = mysql_field_name($result, $x).’
‘;
>
/*
By simply calling the searchtable() function
with these variables it will serach the desired
database and procude a table for each field that
there is a match.
*/
?
function searchtable($host,$user,$pass,$database,$tablename,$userquery)
$link = mysql_connect($host, $user, $pass) or die(«Could not connect: » . mysql_error());
$db = mysql_select_db($database, $link) or die(mysql_error());
$fields = mysql_list_fields($database, $tablename, $link);
$cols = mysql_num_fields($fields);
for ($i = 1; $i < $cols; $i++) $allfields[] = mysql_field_name($fields, $i);
>
foreach ($allfields as $myfield) $result = mysql_query(«SELECT * FROM $tablename WHERE $myfield like ‘%$userquery%’ «);
if (mysql_num_rows($result) > 0) echo «
search $database for $userquery, found match(es) in $myfield:
\n»;
echo «
$myrow[$i] |
\n»;
>
>
>
simple sql to xml converter works with any sql query and returns the name of the table as the root element «row» as each row element and the names of the columns are your children of row. fully tested.
function sqlToXml ( $host , $user , $pass , $database , $tablename , $query )
$link = mysql_connect ( $host , $user , $pass ) or die( «Could not connect: » . mysql_error ());
$db = mysql_select_db ( $database , $link ) or die( mysql_error ());
$result = mysql_query ( $query );
if(! $result )
$numOfCols = mysql_num_fields ( $result );
$numOfRows = mysql_num_rows ( $result );
$info = mysql_fetch_assoc ( $result );
//send headers
header ( ‘Content-type: text/xml’ );
header ( ‘Pragma: public’ );
header ( ‘Cache-control: private’ );
header ( ‘Expires: -1’ );
$xml = » ;
$xml .= » < < $tablename >>» ;
if( $numOfRows > 0 ) <
do <
$xml .= «
foreach( $info as $column => $value ) <
$xml .= » < < $column >> >» ;
>
$xml .= «
>
while ( $info = mysql_fetch_array ( $result ));
>
$xml .= «<> >» ;
mysql_free_result ( $result );
return $xml ;