pg_field_name

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

pg_field_name Retourne le nom d'un champ PostgreSQL

Description

pg_field_name(resource $result, int $field_number): string

pg_field_name() retourne le nom du champ qui occupe la colonne numéro field_number dans le résultat result. La numérotation des champs commence à 0.

Note:

Auparavant, cette fonction s'appelait pg_fieldname().

Liste de paramètres

result

Ressource de résultat de requête PostgreSQL, retournée par pg_query(), pg_query_params() ou pg_execute() (entre autres).

field_number

Numéro du champ, commençant à 0.

Valeurs de retour

Le nom du champ ou false en cas d'erreur.

Exemples

Exemple #1 Récupération d'informations des champs

<?php
 $dbconn 
pg_connect("dbname=publisher") or die("Connexion impossible");

 
$res pg_query($dbconn"select * from auteurs where auteur = 'Orwell'");
 
$i pg_num_fields($res);
 for (
$j 0$j $i$j++) {
     echo 
"colonne $j\n";
     
$fieldname pg_field_name($res$j);
     echo 
"Champ : $fieldname\n";
     echo 
"Taille affichée : ".pg_field_prtlen($res$fieldname)." caractères\n";
     echo 
"Taille de stockage : ".pg_field_size($res$j)." octets\n";
     echo 
"Type de champ : ".pg_field_type($res$j)." \n\n";
 }
?>

L'exemple ci-dessus va afficher :

colonne 0
Champ : auteur
Taille affichée : 6 caractères
Taille de stockage : -1 octets
Type de champ : varchar 

colonne 1
Champ : annee
Taille affichée : 4 caractère
Taille de stockage : 2 octets
Type de champ : int2 

colonne 2
Champ : titre
Taille affichée : 24 caractères
Taille de stockage : -1 octets
Type de champ : varchar 

Voir aussi

add a note add a note

User Contributed Notes 2 notes

up
1
Anonymous
19 years ago
In fact you can extract the size of the varchar field, by simply sending the following query:
"select a.atttypmod,a.attrelid from pg_attribute as a, pg_class as c where c.relname='$table' AND a.attrelid=c.oid AND a.attname='$field'"

here is a simple function that does that:

function get_field_size($table, $field, $link) {
               
        $result = pg_query($link, "select a.atttypmod,a.attrelid from pg_attribute as a, pg_class as c where c.relname='$table' AND a.attrelid=c.oid AND a.attname='$field'");                
       
        $data = pg_fetch_object($result);
       
        return ($data->atttypmod - 4);       
   
}

returned value is a size of a given field (also varchar)
up
1
ccasal at compuserve dot com
23 years ago
The pg_fieldname function only returns the unqualified name from the select statement. example:

select c.name, con.name from customer c, contacts con where con.customer_id = c.id;

pg_fieldname will return "name" for both fields instead of c.name and con.name.

This is a PostgreSQL limitation, not a PHP limitation.

if you need different field names you should use :

select c.name as customer_name, con.name as contact_name from customer c, contacts con where con.customer_id = c.id;

then pg_fieldname will return "customer_name" and "contact_name"
To Top