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.
pg_result_status
(PHP 4 >= 4.2.0, PHP 5)
pg_result_status — Lit le statut du résultat
Description
pg_result_status() retourne le statut du résultat
result ou la commande d'exécution de PostgreSQL
associée au résultat.
Liste de paramètres
-
result -
Ressource résultat de requête PostgreSQL, retourné par pg_query(), pg_query_params() ou pg_execute() (entre autres).
-
type -
Soit
PGSQL_STATUS_LONGpour retourner un statut numérique deresultouPGSQL_STATUS_STRINGpour retourner le tag de la commande deresult. Si l'argument n'est pas spécifié,PGSQL_STATUS_LONGest la valeur par défaut.
Valeurs de retour
Les valeurs de retour possibles sont PGSQL_EMPTY_QUERY,
PGSQL_COMMAND_OK, PGSQL_TUPLES_OK,
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é.
Historique
| Version | Description |
|---|---|
| 4.3.0 |
Le paramètre type a été ajouté.
|
Exemples
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.
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).
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
