Change seconds argument of make_*() functions to numeric

Started by Peter Eisentrautover 5 years ago3 messageshackers
Jump to latest
#1Peter Eisentraut
peter_e@gmx.net

Along with the discussed change of the return type of EXTRACT from
float8 to numeric [0]/messages/by-id/42b73d2d-da12-ba9f-570a-420e0cce19d9@phystech.edu, I was looking around what other date/time APIs
might be using float arguments or return values. The only thing left
appears to be the functions make_time, make_timestamp, make_timestamptz,
and make_interval, which take an argument specifying the seconds, which
has type float8 right now. I'm proposing the attached patch to change
that to numeric.

Can we change the arguments, as proposed here, or do we need to add
separate overloaded versions and leave the existing versions in place?

[0]: /messages/by-id/42b73d2d-da12-ba9f-570a-420e0cce19d9@phystech.edu
/messages/by-id/42b73d2d-da12-ba9f-570a-420e0cce19d9@phystech.edu

Attachments:

0001-Change-seconds-argument-of-make_-functions-to-numeri.patchtext/plain; charset=UTF-8; name=0001-Change-seconds-argument-of-make_-functions-to-numeri.patch; x-mac-creator=0; x-mac-type=0Download+67-56
#2Pavel Stehule
pavel.stehule@gmail.com
In reply to: Peter Eisentraut (#1)
Re: Change seconds argument of make_*() functions to numeric

čt 17. 12. 2020 v 17:43 odesílatel Peter Eisentraut <
peter.eisentraut@enterprisedb.com> napsal:

Along with the discussed change of the return type of EXTRACT from
float8 to numeric [0], I was looking around what other date/time APIs
might be using float arguments or return values. The only thing left
appears to be the functions make_time, make_timestamp, make_timestamptz,
and make_interval, which take an argument specifying the seconds, which
has type float8 right now. I'm proposing the attached patch to change
that to numeric.

Can we change the arguments, as proposed here, or do we need to add
separate overloaded versions and leave the existing versions in place?

What this change does with views. Can it break upgrade by pg_upgrade?

Regards

Pavel

Show quoted text

[0]:

/messages/by-id/42b73d2d-da12-ba9f-570a-420e0cce19d9@phystech.edu

#3Tom Lane
tgl@sss.pgh.pa.us
In reply to: Peter Eisentraut (#1)
Re: Change seconds argument of make_*() functions to numeric

Peter Eisentraut <peter.eisentraut@enterprisedb.com> writes:

Along with the discussed change of the return type of EXTRACT from
float8 to numeric [0], I was looking around what other date/time APIs
might be using float arguments or return values. The only thing left
appears to be the functions make_time, make_timestamp, make_timestamptz,
and make_interval, which take an argument specifying the seconds, which
has type float8 right now. I'm proposing the attached patch to change
that to numeric.

I don't really see the point here. Since the seconds value is constrained
to 0..60 and will be rounded off to microseconds, you would have to work
seriously hard to find an example where float8 roundoff error could be
a problem. I don't think we should take whatever speed and compatibility
hit is implied by using numeric instead of float8.

(make_interval in theory could be an exception, since it doesn't constrain
the range of seconds values. But I still don't believe there's a problem
in practice.)

Can we change the arguments, as proposed here, or do we need to add
separate overloaded versions and leave the existing versions in place?

Since there's no implicit float8 to numeric cast, removing the existing
versions could quite easily cause failures of queries that work today.

regards, tom lane