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
(PHP 4 >= 4.2.0, PHP 5, PHP 7, PHP 8)
pg_result_status — Lit le statut du résultat
pg_result_status() retourne le statut du résultat
result
ou la commande d'exécution de PostgreSQL
associée au résultat.
result
Une instance PgSql\Result, retourné par pg_query(), pg_query_params(), ou pg_execute() (entre autres).
mode
Soit PGSQL_STATUS_LONG
pour retourner un statut
numérique de result
ou
PGSQL_STATUS_STRING
pour retourner le tag de la
commande de result
. Si l'argument n'est pas
spécifié, PGSQL_STATUS_LONG
est la valeur par
défaut.
Les valeurs de retour possibles sont PGSQL_EMPTY_QUERY
,
PGSQL_COMMAND_OK
, PGSQL_TUPLES_OK
,
PGSQL_TUPLES_CHUNK
, PGSQL_COPY_OUT
,
PGSQL_COPY_IN
, PGSQL_BAD_RESPONSE
,
PGSQL_NONFATAL_ERROR
et PGSQL_FATAL_ERROR
si PGSQL_STATUS_LONG
est
spécifié. Autrement, une chaîne contenant le tag de la commande PostgreSQL
est retourné.
Version | Description |
---|---|
8.1.0 |
Le paramètre result attend désormais une instance de
PgSql\Result ; auparavant, une resource était attendu.
|
Exemple #1 Exemple avec pg_result_status()
<?php
// Connexion à la base de données
$conn = pg_pconnect("dbname=publisher");
// Exécution de COPY
$result = pg_query($conn, "COPY auteurs FROM STDIN;");
// Récupération du statut
$status = pg_result_status($result);
// Détermination du statut
if ($status == PGSQL_COPY_IN)
echo "Le copiage a eu lieu.";
else
echo "Le copiage a échoué.";
?>
L'exemple ci-dessus va afficher :
Le copiage a eu lieu.
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
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
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.