Re: [HACKERS] Re: [INTERFACES] retrieving varchar size - Mailing list pgsql-hackers

From Hannu Krosing
Subject Re: [HACKERS] Re: [INTERFACES] retrieving varchar size
Date
Msg-id 353FA3F1.F5FC0996@sid.trust.ee
Whole thread Raw
In response to Re: [HACKERS] Re: [INTERFACES] retrieving varchar size  (Bruce Momjian <maillist@candle.pha.pa.us>)
Responses Re: [HACKERS] Re: [INTERFACES] retrieving varchar size  (Bruce Momjian <maillist@candle.pha.pa.us>)
List pgsql-hackers
David Hartwig wrote:
>
> Bruce Momjian wrote:
>
> > >
> > > In the latter case, I would suggest an additional SQL command for open
> > > cursors,
> > > or a pseudo table for open cursor where you could do a simple select
> > > statement:
> > >
> > > DECLARE CURSOR FOO_CURSOR FOR SELECT * FROM MYTABLE;
> > >
> > > SELECT _FIELD_NAME,_FIELD_TYPE,_FIELD_SIZE FROM
> > > FOO_CURSOR_INFO_PSEUTOTABLE;
> >
> > The information you want is in pg_attribute.atttypmod.  It is normally
> > -1, but is set for char() and varchar() fields, and includes the 4-byte
> > length.  See bin/psql/psql.c for a sample of its use.

is this on client side or server side?

Last time I checked (it was in 6.2 protocol) it was not sent to client.

What I need is the defined max length of varchar (or char), not just
actual length of each field of that type. This is used by Borlands BDE,
and if this changes, depending on the where clause, it breaks BDE.

> I see everyone writing in terms of length.   You do mean precision, don't
> you?

in case varchars have precision, yes ;)

>   For our purposes, this precision should  arrive in the result
> header.   (redundancy in each tuple could be over looked)   The goal is to be
> able to put realistic bounds on memory allocation before the entire result is
> read in.   For this to work, functions must also be able to propagate the
> their precision.

Yes, the functions should behave as objects, so that you can get
metadata on them.

So functions should know, depending on max lengths of their arguments,
how long strings they return.

But even without this functionality, having this info is essential to
getting Borland stuff to work.

> Did I spell doom to this idea?

I hope not.

Hannu

pgsql-hackers by date:

Previous
From: David Hartwig
Date:
Subject: Re: [HACKERS] Re: [INTERFACES] retrieving varchar size
Next
From: darrenk@insightdist.com (Darren King)
Date:
Subject: linux, bsd, i386-solaris and univel shared libraries.