Re: BUG #13885: float->string conversion loses precision server-side on JDBC connection

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: BUG #13885: float->string conversion loses precision server-side on JDBC connection
Дата
Msg-id 11278.1453738005@sss.pgh.pa.us
обсуждение исходный текст
Ответ на BUG #13885: float->string conversion loses precision server-side on JDBC connection  (xtracoder@gmail.com)
Ответы Re: BUG #13885: float->string conversion loses precision server-side on JDBC connection  (Xtra Coder <xtracoder@gmail.com>)
Список pgsql-bugs
xtracoder@gmail.com writes:
> I have a PostgreSQL function, which accepts JSON, performs some processing,
> and returns JSON. Something strange is happening when calling stored
> procedure from Java application - float->string conversion is incorrect.

I don't think it's "incorrect".  I believe the displayed difference here
is because the JDBC driver sets extra_float_digits to 3 or so.
Compare this in psql:

regression=# do $$ declare x float := 4.1; begin raise notice 'x = %', x; end$$;
NOTICE:  x = 4.1
DO
regression=# set extra_float_digits = 3;
SET
regression=# do $$ declare x float := 4.1; begin raise notice 'x = %', x; end$$;
NOTICE:  x = 4.09999999999999964
DO

The uglier-looking number is a more precise representation of the actual
float4 value.

            regards, tom lane

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

Предыдущее
От: kunschikov@gmail.com
Дата:
Сообщение: BUG #13888: pg_dump write error
Следующее
От: Alvaro Herrera
Дата:
Сообщение: Re: BUG #13888: pg_dump write error