Re: Error in DatabaseMetaData.getColumns() with Views

Поиск
Список
Период
Сортировка
От Kris Jurka
Тема Re: Error in DatabaseMetaData.getColumns() with Views
Дата
Msg-id Pine.BSO.4.56.0407030343090.19721@leary.csoft.net
обсуждение исходный текст
Ответ на Error in DatabaseMetaData.getColumns() with Views  (Dario Fassi <dariovfassi@yahoo.com.ar>)
Ответы Re: Error in DatabaseMetaData.getColumns() with Views  ("Dario V. Fassi" <software@sistemat.com.ar>)
Список pgsql-jdbc

On Fri, 2 Jul 2004, Dario Fassi wrote:

> Hi, I wish to report a erroneous information returned by
> DatabaseMetaData.getColumns()  method.
>
> This happens with ResultSet's column (7) COLUMN_SIZE  and  (9)
> DECIMAL_DIGITS ,
> when DatabaseMetaData.getColumns() inform about a VIEW with columns
> formed with :
> coalesce , case or numeric operations over DECIMAL fields.
>
> Suppose
>
> CREATE TABLE A (  f1 DEC(6,3), f2 dec(6,3) );
> CREATE VIEW B as ( select ( f1 + f2 ) as f from a;
>
> Then DatabaseMetaData.getColumns() returns:
>
> VIEW B
>     F   NUMERIC(  65535 ,  -65531 )
>

The problem is that f1+f2 does not retain the numeric(6,3) size
restriction, but turns into an unbounded plain "numeric" datatype.  So
when retrieving this data the precision/scale are unavailable and the
unreasonable values you see are returned.  We could return NULL instead,
but I'm not sure that would be much more helpful if the client is
expecting real values.  Any other ideas?

Kris Jurka


В списке pgsql-jdbc по дате отправления:

Предыдущее
От: tania gutierrez
Дата:
Сообщение: error en coneccion a postgresql
Следующее
От: Dario Fassi
Дата:
Сообщение: Re: Error in DatabaseMetaData.getColumns() with Views