(PHP 4 >= 4.2.0, PHP 5)

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


int pg_num_rows ( resource $result )

pg_num_rows() возвращает количество строк в результате запроса PostgreSQL.


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

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


Результат запроса PostgreSQL, возвращаемый функциями pg_query(), pg_query_params() или pg_execute() (и прочими).

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

Количество строк в выборке. В случае ошибки возвращает -1.


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

pg_query($conn"SELECT 1");

$rows pg_num_rows($result);

"Возвращено строк: " $rows ".\n";

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

Возвращено строк: 1.

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

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


Not sure why this documentation doesn't have the following note:
Note: Use pg_affected_rows() to get number of rows affected by INSERT, UPDATE and DELETE query.

Found on other resources. Adding here in case someone else is looking for the info.
2008-01-07 10:26:27
About preceding note, you shouldn't use pg_num_rows() for this.
You should have instead a look at pg_affected_rows().
2008-10-06 10:09:58
As mentioned, if you are performing an INSERT/UPDATE or DELETE query and want to know the # of rows affected, you should use pg_affected_rows() instead of pg_num_rows().

However, you can also exploit postgres's RETURNING clause in your query to auto-select columns from the affected rows.  This has the advantage of being able to tell not only how many rows a query affects, but exactly which rows those were, especially if you return a primary-key column.

For example:


// Example query.  Let's say that this updates five rows in the source table.
$res pg_query("Update foo set bar = 'new data' where = 'old data' ");
pg_num_rows($res); // 0
pg_affected_rows($res); // 5
pg_fetch_all($res); // FALSE

// Same query, with a RETURNING clause.
$res pg_query("Update foo set bar = 'new data' where = 'old data' RETURNING foo.pkey");
pg_num_rows($res); // 5
pg_affected_rows($res); // 5
pg_fetch_all($res); // Multidimensional array corresponding to our affected rows & returned columns
2009-05-10 13:06:10

    Поддержать сайт на родительском проекте КГБ