PHPerKaigi 2025

pg_num_fields

(PHP 4 >= 4.2.0, PHP 5, PHP 7, PHP 8)

pg_num_fieldsВозвращает количество полей в выборке

Описание

pg_num_fields(PgSql\Result $result): int

pg_num_fields() возвращает количество полей (столбцов) в экземпляре PgSql\Result.

Замечание:

Ранее функция называлась pg_numfields().

Список параметров

result

Экземпляр класса PgSql\Result, который возвращают функции pg_query(), pg_query_params() или pg_execute() (среди прочего).

Возвращаемые значения

Количество полей (столбцов) в выборке. В случае возникновения ошибки возвращает -1.

Список изменений

Версия Описание
8.1.0 Параметр result теперь ожидает экземпляр класса PgSql\Result; раньше параметр ожидал ресурс (resource).

Примеры

Пример #1 Пример использования pg_num_fields()

<?php
$result
= pg_query($conn, "SELECT 1, 2");

$num = pg_num_fields($result);

echo
"Возвращено полей: " . $num . ".\n";
?>

Результат выполнения приведённого примера:

Возвращено полей: 2.

Смотрите также

  • pg_num_rows() - Возвращает количество строк в выборке
  • pg_affected_rows() - Возвращает количество затронутых запросом записей (кортежей)

Добавить

Примечания пользователей 1 note

up
-1
mark at redbrick dot dcu dot ie
21 years ago
Here is a simple example for using pg_num_feilds, pg_num_rows and pg_result together. I'm simply SELECTing * from a table named markie on the current pg_connect().

<?php
$pgsql_conn
= pg_connect("dbname=mark host=localhost");

if (!
$pgsql_conn) {
print
pg_last_error($pgsql_conn);
exit;
}

$results = pg_query($pgsql_conn, "SELECT * FROM markie");

echo
"<table border=1>\n";
for(
$lt = 0; $lt < pg_num_rows($results); $lt++) {
echo
"<tr>\n";
for(
$gt = 0; $gt < pg_num_fields($results); $gt++) {
echo
"<td>" . pg_result($results, $lt, $gt) . "</td>\n";
}
echo
"</tr>\n";
}
echo
"</table>\n";

pg_close($pgsql_conn);
?>

This code snippet will print out the rows and columns into a HTML table.

Regards, --mark
To Top