On Mon, 9 Oct 2023 at 18:46, Nick Babadzhanian <pgni...@gmail.com> wrote:
>
> On Thu, 31 Aug 2023 at 23:10, Andrey M. Borodin <x4...@yandex-team.ru> wrote:
> > Well, as far as I know, RFC discourages extracting timestamps from UUIDs. 
> > But we still can have such functions...maybe as an extension?
>
> Do you know of any reason for that?

No reasons are given but the RFC states this:

> UUIDs SHOULD be treated as opaque values and implementations SHOULD NOT 
> examine the bits in a UUID to whatever extent is possible. However, where 
> necessary, inspectors should refer to Section 4 for more information on 
> determining UUID version and variant.

> > However, so far I haven't figured out how to implement optional arguments 
> > for catalog functions. I'd appreciate any pointers here.
>
> I'd argue that the time argument shouldn't be optional. Asking the
> user to supply time would force them to think whether they want to go
> with `now()` or `clock_timestamp()` or something else.

I think using `now()` is quite prone to sequence rollover. With the
current patch inserting more than 2^18~=0.26M rows into a table with
`gen_uuid_v7()` as the default in a single transaction would already
cause sequence rollover. I think using a monotonic clock source is the
only reasonable thing to do. From the RFC:

> Implementations SHOULD use the current timestamp from a reliable source to 
> provide values that are time-ordered and continually increasing. Care SHOULD 
> be taken to ensure that timestamp changes from the environment or operating 
> system are handled in a way that is consistent with implementation 
> requirements. For example, if it is possible for the system clock to move 
> backward due to either manual adjustment or corrections from a time 
> synchronization protocol, implementations must decide how to handle such 
> cases. (See Altering, Fuzzing, or Smearing bullet below.)


Reply via email to