PG Doc comments form <nore...@postgresql.org> writes:
> "64.4.3. Deduplication" says:
> "numeric cannot use deduplication. Numeric display scale must be preserved
> among equal datums."

> However I don't understand this. An equal datum is an equal datum regardless
> of display scale, isn't it?

No.  For example:

regression=# select 1.0, 1.00;
 ?column? | ?column? 
----------+----------
      1.0 |     1.00
(1 row)

regression=# select 1.0 = 1.00;
 ?column? 
----------
 t
(1 row)

These values are "equal" per the datatype's equality operator,
but there are some operations (not only output) that can distinguish
them, so the index can't lump them together.

There are similar issues in some other datatypes, for example
zero and minus zero in the float types.

                        regards, tom lane


Reply via email to