Нямате нужда от допълнителна SQL заявка, само за да получите имената на полетата си. Можете да използвате вашата нормална заявка SELECT и просто да получите имената на полетата (и дефинициите) от тази заявка. По-добра производителност по този начин!
Остаряло решение за MySQL:
MySQL библиотеката е остаряла. Може да се използва както в тази връзка, но трябва да преминете към библиотеката mysqli, която е почти идентична, когато се използва процедурно (втора проба).
htttp://www.php.net/manual/en/function.mysql-field-name.php
ООП MySQLi решението:
$query = "SELECT Name, SurfaceArea from Country ORDER BY Code LIMIT 5";
if ($result = $mysqli->query($query)) {
/* Get field information for all columns */
while ($finfo = $result->fetch_field()) {
printf("Name: %s\n", $finfo->name);
printf("Table: %s\n", $finfo->table);
printf("max. Len: %d\n", $finfo->max_length);
printf("Flags: %d\n", $finfo->flags);
printf("Type: %d\n\n", $finfo->type);
}
$result->close();
}
Процедурното решение на MySQLi:
$query = "SELECT Name, SurfaceArea from Country ORDER BY Code LIMIT 5";
if ($result = mysqli_query($link, $query)) {
/* Get field information for all fields */
while ($finfo = mysqli_fetch_field($result)) {
printf("Name: %s\n", $finfo->name);
printf("Table: %s\n", $finfo->table);
printf("max. Len: %d\n", $finfo->max_length);
printf("Flags: %d\n", $finfo->flags);
printf("Type: %d\n\n", $finfo->type);
}
mysqli_free_result($result);
}
http://www.php.net/manual/en /mysqli-result.fetch-field.php