BUG #17546: power() function - value is distorted via automatic type cast

Поиск
Список
Период
Сортировка
От PG Bug reporting form
Тема BUG #17546: power() function - value is distorted via automatic type cast
Дата
Msg-id 17546-d71fe78a505f9f7b@postgresql.org
обсуждение исходный текст
Ответы Re: BUG #17546: power() function - value is distorted via automatic type cast  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-bugs
The following bug has been logged on the website:

Bug reference:      17546
Logged by:          Su Sinodan
Email address:      su.sinodan@gmail.com
PostgreSQL version: 14.2
Operating system:   Windows Server 2016 (10.0.14393 Build 1439)
Description:

When a certain number (p, s) with a fractional part (specific examples -
1.11 and 69.96) is multiplied by a power (10, N), the resulting value is
distorted.
However, if the power(10, N) is manually converted to an integer, the
resulting value is correct.
It looks like there is some kind of problem with the automatic type
conversion of the power() function.

Test query:
with w_degree as (
                   select 0::integer as degree union all
                   select 1::integer as degree union all
                   select 2::integer as degree union all
                   select 3::integer as degree union all
                   select 4::integer as degree union all
                   select 5::integer as degree union all
                   select 6::integer as degree union all
                   select 7::integer as degree union all
                   select 8::integer as degree union all
                   select 9::integer as degree
                 )
select
  power(10, w.degree::integer)                                  as
"power()"
, 1.11::numeric(20, 5) * power(10, w.degree::integer)           as " 1.11 *
power()"
, 1.11::numeric(20, 5) * power(10, w.degree::integer)::integer  as " 1.11 *
power()::integer"
, 69.96::numeric(20, 5) * power(10, w.degree::integer)          as "69.96 *
power()"
, 69.96::numeric(20, 5) * power(10, w.degree::integer)::integer as "69.96 *
power()::integer"
from w_degree w;

Result:
  power()   |   1.11 * power()   |  1.11 * power()::integer |  69.96 *
power()  | 69.96 * power()::integer
------------+--------------------+--------------------------+-------------------+--------------------------
          1 |               1.11 |                  1.11000 |
69.96 |                 69.96000
         10 | 11.100000000000001 |                 11.10000 |
699.5999999999999 |                699.60000
        100 | 111.00000000000001 |                111.00000 |
6995.999999999999 |               6996.00000
       1000 |               1110 |               1110.00000 |
69960 |              69960.00000
      10000 | 11100.000000000002 |              11100.00000 |
699599.9999999999 |             699600.00000
     100000 | 111000.00000000001 |             111000.00000 |
6995999.999999999 |            6996000.00000
    1000000 |            1110000 |            1110000.00000 |
69960000 |           69960000.00000
   10000000 | 11100000.000000002 |           11100000.00000 |
699599999.9999999 |          699600000.00000
  100000000 | 111000000.00000001 |          111000000.00000 |
6995999999.999999 |         6996000000.00000
 1000000000 |         1110000000 |         1110000000.00000 |
69960000000 |        69960000000.00000
(10 rows)


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

Предыдущее
От: PG Bug reporting form
Дата:
Сообщение: BUG #17545: Incorrect selectivity for IS NOT DISTINCT FROM and NULLs
Следующее
От: Tom Lane
Дата:
Сообщение: Re: BUG #17546: power() function - value is distorted via automatic type cast