pg_result_status

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

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

Описание

mixed pg_result_status ( resource $result [, int $type = PGSQL_STATUS_LONG ] )

pg_result_status() возвращает текущее состояние ресурса результата запроса, либо тэг завершения сервером работы с с этим ресурсом.

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

result

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

type

Принимает одно из двух значений: PGSQL_STATUS_LONG для получения числового обозначения состояния result, либо PGSQL_STATUS_STRING для получения тэга состояния в виде строки. По умолчанию используется PGSQL_STATUS_LONG.

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

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

Примеры

Пример #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.

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

Коментарии

0 = PGSQL_EMPTY_QUERY
1 = PGSQL_COMMAND_OK
2 = PGSQL_TUPLES_OK
3 = PGSQL_COPY_TO
4 = PGSQL_COPY_FROM
5 = PGSQL_BAD_RESPONSE
6 = PGSQL_NONFATAL_ERROR
7 = PGSQL_FATAL_ERROR
2002-10-16 09:29:27
http://php5.kiev.ua/manual/ru/function.pg-result-status.html
Автор:
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).
2005-06-08 21:45:33
http://php5.kiev.ua/manual/ru/function.pg-result-status.html
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.html

Therefore you cannot use this function to check if this query produced a notice.
2013-02-01 17:50:58
http://php5.kiev.ua/manual/ru/function.pg-result-status.html
Автор:
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 example

if(($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
2014-03-01 20:44:26
http://php5.kiev.ua/manual/ru/function.pg-result-status.html

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