pg_result_status

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

pg_result_status Возвращает статус результата запроса

Описание

pg_result_status(PgSql\Result $result, int $mode = PGSQL_STATUS_LONG): string|int

Функция pg_result_status() возвращает текущий статус экземпляра PgSql\Result или тег завершения PostgreSQL-команды, который связан с результатом.

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

result

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

mode

Параметр принимает значение PGSQL_STATUS_LONG для возврата числового статуса, который содержится в объекте с результатами запроса и который передали в аргументе result, или значение PGSQL_STATUS_STRING для возврата тега команды из того же объекта с результатами запроса — result. Значение по умолчанию равно PGSQL_STATUS_LONG.

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

При передаче в аргументе константы PGSQL_STATUS_LONG функция возвращает константу из следующего списка: PGSQL_EMPTY_QUERY, PGSQL_COMMAND_OK, PGSQL_TUPLES_OK, PGSQL_TUPLES_CHUNK, PGSQL_COPY_OUT, PGSQL_COPY_IN, PGSQL_BAD_RESPONSE, PGSQL_NONFATAL_ERROR, PGSQL_FATAL_ERROR. В остальных случаях функция вернёт строковое представление состояния результата запроса.

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

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

Примеры

Пример #1 Пример возврата статуса результата запроса функцией pg_result_status()

<?php

// Подключаемся к базе данных
$conn = pg_pconnect("dbname=publisher");

// Выполняем команду COPY
$result = pg_query($conn, "COPY authors FROM STDIN;");

// Получаем состояние результата запроса
$status = pg_result_status($result);

// Разбираем полученные данные
if ($status == PGSQL_COPY_IN) {
echo
"Copy began.";
} else {
echo
"Copy failed.";
}

?>

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

Copy began.

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

Добавить

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

up
1
romix at gmx dot de
22 years ago
0 = PGSQL_EMPTY_QUERY1 = PGSQL_COMMAND_OK2 = PGSQL_TUPLES_OK3 = PGSQL_COPY_TO4 = PGSQL_COPY_FROM5 = PGSQL_BAD_RESPONSE6 = PGSQL_NONFATAL_ERROR7 = PGSQL_FATAL_ERROR
up
1
Anonymous
11 years ago
This function is useful it may not return a  full non fatal error but you want to see if the query completes anyway.example<?PHP//connect to pg database// create PGSQL$PGSTAT = pg_result_status($PGSQL);//defaults to long//And run it through a check for exampleif(($PGSTAT == 1) || ($PGSTAT == 2)){ // for query results;}else if(($PGSTAT == 3) || ($PGSTAT == 4)){ // for copy results;}if(($PGSTAT != 0) && ($PGSTAT != 5) && ($PGSTAT != 6) && ($PGSTAT != 7)){// your code;}else{ // $ERRORS codes;}// This is worked the best for me so far  I tried using // The command tag and I seem to still get an numeric result//example//$PGSTAT = pg_result_status($PGSQL, PGSQL_COMMAND_OK);// got something like tuples ok so I recommend just use default long?>or use what ever condition check you feel fit
up
0
dean at deansas dot org
12 years ago
The postgres docs say that PHP should never be able to return PGRES_NONFATAL_ERROR"A result of status PGRES_NONFATAL_ERROR will never be returned directly by PQexec or other query execution functions" http://www.postgresql.org/docs/current/static/libpq-exec.htmlTherefore you cannot use this function to check if this query produced a notice.
up
-1
Meej Vaj
20 years ago
If on "accident" your program passes pg_result_status a variable that is NOT a actual pg resource, it will return an empty string.(This is important to know if you want to make sure a pg resource is "good" before attempting some operation on it).
To Top