this post was submitted on 30 Jun 2024
5 points (55.8% liked)

Programming

17853 readers
222 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities [email protected]



founded 2 years ago
MODERATORS
 

This document presents new time-based UUID formats which are suited for use as a database key.

top 8 comments
sorted by: hot top controversial new old
[–] [email protected] 28 points 6 months ago (1 children)

Why did you post a 3 year old expired draft whose proposed implementation has been obsoleted?

[–] [email protected] 0 points 6 months ago
[–] [email protected] 6 points 6 months ago (1 children)

For others wondering what's wrong with UUIDv4:

UUID versions that are not time ordered, such as UUIDv4, have poor database-index locality. This means that new values created in succession are not close to each other in the index; thus, they require inserts to be performed at random locations. The resulting negative performance effects on the common structures used for this (B-tree and its variants) can be dramatic.

I guess, this means with these new UUIDs, ideally you only create UUIDs on systems that are hooked up to NTP, though I guess, it won't really be worse than UUIDv4 either way.

[–] [email protected] 6 points 6 months ago (1 children)

My understanding is that as long as IDs are roughly the same range of the index instead of literally random, it reduces the thrashing about needed for indexing these. It probably doesn't need to be perfectly exact. They're talking about B-trees, so these would all be modifying the same smaller branches of the tree instead of going in all over the place.

[–] [email protected] 2 points 6 months ago (1 children)

Yeah, that is my understanding, too. Otherwise you'd only want to generate them on the database host, as even with NTP there will be small differences. This would kind of defeat the purpose of UUIDs.

If you're saying that even without NTP, just by manually setting the time, things will be fine. I mean, maybe. But I've seen it far too many times already that some host shows up with 1970-01-01...

[–] [email protected] 2 points 6 months ago

Haha, that's fair, someone absolutely would manage to write 1970s dates if they aren't pulling the current time.

[–] [email protected] 3 points 6 months ago (1 children)

Isn't that relatively old news? I've been using them in Symfony for a few years, already.

[–] [email protected] 2 points 6 months ago

Publish was 2021 so yeah a couple years old