ulid: Generate Universally Unique 'Lexicographically' 'Sortable' Identifiers

Universally unique identifiers ('UUIDs') can be sub-optimal for many uses-cases because they are not the most character efficient way of encoding 128 bits of randomness; v1/v2 versions are impractical in many environments, as they require access to a unique, stable MAC address; v3/v5 versions require a unique seed and produce randomly distributed IDs, which can cause fragmentation in many data structures; v4 provides no other information than randomness which can cause fragmentation in many data structures. Providing an alternative, 'ULIDs' (<https://github.com/ulid/spec>) have 128-bit compatibility with 'UUID', 1.21e+24 unique 'ULIDs' per millisecond, support standard (text) sorting, canonically encoded as a 26 character string, as opposed to the 36 character 'UUID', use 'base32' encoding for better efficiency and readability (5 bits per character), are case insensitive, have no special characters (i.e. are 'URL' safe) and have a monotonic sort order (correctly detects and handles the same millisecond).

Getting started

Package details

AuthorBob Rudis [aut] (<https://orcid.org/0000-0001-5670-2640>), Suyash Verma [aut] (ULID C++ <https://github.com/suyash/ulid/>), Dirk Eddelbuettel [cre] (<https://orcid.org/0000-0001-6419-907X>)
MaintainerDirk Eddelbuettel <edd@debian.org>
LicenseMIT + file LICENSE
Version0.4.0
URL https://github.com/eddelbuettel/ulid
Package repositoryView on CRAN
Installation Install the latest version of this package by entering the following in R:
install.packages("ulid")

Try the ulid package in your browser

Any scripts or data that you put into this service are public.

ulid documentation built on June 22, 2024, 9:22 a.m.