pg_field_size

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

pg_field_size Retorna o tamanho de armazenamento interno do campo nomeado

Descrição

pg_field_size(PgSql\Result $result, int $field): int

pg_field_size() retorna o tamanho do armazenamento interno (em bytes) do número do campo no result do PostgreSQL fornecido.

Nota:

Esta função costumava ser chamada de pg_fieldsize().

Parâmetros

result

Uma instância de PgSql\Result, retornada por pg_query(), pg_query_params() ou pg_execute() (entre outras).

field

Número do campo, começando em 0.

Valor Retornado

O tamanho do armazenamento do campo interno (em bytes). -1 indica um campo de comprimento variável.

Registro de Alterações

Versão Descrição
8.1.0 O parâmetro result agora espera uma instância de PgSql\Result; anteriormente, um resource era esperado.

Exemplos

Exemplo #1 Obtendo informações sobre campos

<?php
$dbconn
= pg_connect("dbname=publisher") or die("Não foi possível conectar");

$res = pg_query($dbconn, "select * from authors where author = 'Orwell'");
$i = pg_num_fields($res);
for (
$j = 0; $j < $i; $j++) {
echo
"coluna $j\n";
$fieldname = pg_field_name($res, $j);
echo
"nome do campo: $fieldname\n";
echo
"comprimento impresso: " . pg_field_prtlen($res, $fieldname) . " caracteres\n";
echo
"comprimento de armazenamento: " . pg_field_size($res, $j) . " bytes\n";
echo
"tipo do campo: " . pg_field_type($res, $j) . " \n\n";
}
?>

O exemplo acima produzirá:

coluna 0
nome do campo: author
comprimento impresso: 6 caracteres
comprimento de armazenamento: -1 bytes
tipo do campo: varchar

coluna 1
nome do campo: year
comprimento impresso: 4 caracteres
comprimento de armazenamento: 2 bytes
tipo do campo: int2

coluna 2
nome do campo: title
comprimento impresso: 24 caracteres
comprimento de armazenamento: -1 bytes
tipo do campo: varchar

Veja Também

adicione uma nota

Notas Enviadas por Usuários (em inglês) 3 notes

up
0
ij at NOSPAM dot irj dot co dot za
20 years ago
To view the file structure of a table using a sql queryselect pg_class.relname, pg_attribute.attname, pg_type.typname, pg_type.typlen from pg_class, pg_attribute, pg_type  where pg_class.relname = 'YOURTABLENAME' and pg_class.oid = pg_attribute.attrelid and pg_type.oid = pg_attribute.atttypid having attnum > 0
up
0
php at tribun dot de
20 years ago
function get_create_syntax( $table ){  $qry  =  "            SELECT    *            FROM      $table            LIMIT     1          ";  $res = pg_query( $qry );  $row = pg_fetch_assoc( $res );  $create = "CREATE TABLE $table \n(\n";  $item = array();  for( $i = 0; $i < count( $row ); $i++ )  {    $name = pg_field_name( $res, $i );    $type = pg_field_type( $res, $i );    $size = pg_field_size( $res, $i );    $item[$i] = '"'.$name.'" '.$type;    $qry  =  "              SELECT    a.atttypmod    AS size,                        a.attnotnull  AS notnull              FROM      pg_attribute  AS a,                        pg_class      AS c              WHERE     c.relname   = '$table'              AND       a.attrelid  =  c.oid              AND       a.attname    =  '$name'             ";    $res2  = pg_query( $qry );    $out  = pg_fetch_object( $res2 );    if( $out -> size != -1 )    {      $item[$i] .= '('.( $out -> size - 4 ).')';    }    if( $out -> notnull == 't' )    $item[$i] .= ' NOT';    $item[$i] .= ' NULL';  }  $create .= implode( ",\n", $item ) ."\n);";  return $create;}
up
-3
alex at linuxNOSPAM dot org dot pe
23 years ago
How i can extract the struct of a Postgresql Table?I want to do a dynamic php code, that see the pg table, and print name, type and size of fields
To Top