Movatterモバイル変換


[0]ホーム

URL:


Type:Package
Title:Generate Universally Unique 'Lexicographically' 'Sortable'Identifiers
Version:0.4.0
Date:2024-06-03
Description: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).
URL:https://github.com/eddelbuettel/ulid
BugReports:https://github.com/eddelbuettel/ulid/issues
NeedsCompilation:yes
Encoding:UTF-8
License:MIT + file LICENSE
Suggests:tinytest
Imports:Rcpp
LinkingTo:Rcpp
RoxygenNote:7.3.1
Packaged:2024-06-03 16:30:26 UTC; edd
Author:Bob RudisORCID iD [aut], Suyash Verma [aut] (ULID C++ <https://github.com/suyash/ulid/>), Dirk EddelbuettelORCID iD [cre]
Maintainer:Dirk Eddelbuettel <edd@debian.org>
Repository:CRAN
Date/Publication:2024-06-04 09:52:31 UTC

Generate ULID

Description

generate() generates a newUniversally Unique Lexicographically Sortable Identifier. Several aliases areavailable for convience and backwards-compatibility.

This function generates a newUniversally Unique Lexicographically Sortable Identifier from a vector ofPOSIXct timestamps.

As described in theulid specification repo, and slightly edited here,UUID use can be suboptimal for many uses-cases because:(grifted fromhttps://github.com/ulid/spec)

UUID can be suboptimal for many uses-cases because:

Instead, an alternative is proposed in ULID:

ulid() // 01ARZ3NDEKTSV4RRFFQ69G5FAV

with the following properties:

01AN4Z07BY      79KA1307SR9X4MV3|----------|    |----------------|  Timestamp          Randomness   48bits              80bits

Components

Timestamp

Randomness

Sorting

The left-most character must be sorted first, and the right-most character sorted last (lexical order).The default ASCII character set must be used. Within the same millisecond, sort order is not guaranteed.

Usage

generate(n = 1L)unmarshal(ulids)ts_generate(tsv)ulid(n = 1L)ulid_generate(n = 1L)ULIDgenerate(n = 1L)

Arguments

n

number of id's to generate (default =1)

ulids

character ULIDs (e.g. created withgenerate())

tsv

vector ofPOSIXct values

Details

Note that up until release 0.3.1, the implementations had limitationsthat resulted in second rather than millisecond resolution. This hasbeen addressed for release 0.4.0 and is now supported as expected.

Value

Adata.frame with two columnsts andrnd.

Author(s)

Bob Rudis (bob@rud.is) wrote the package based onulid C++ library by Suyash Verma.

Dirk Eddelbuettel now maintains the package.

See Also

Theulid specification provides the reference.

Examples

ULIDgenerate()unmarshal(generate())ts_generate(as.POSIXct("2017-11-01 15:00:00", origin="1970-01-01"))

[8]ページ先頭

©2009-2025 Movatter.jp