js-id VS pg-ulid

Compare js-id vs pg-ulid and see what are their differences.

js-id

ID generation for JavaScript & TypeScript Applications (by MatrixAI)

pg-ulid

ULID Functions for PostgreSQL (by edoceo)
SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
With SurveyJS form UI libraries, you can build and style forms in a fully-integrated drag & drop form builder, render them in your JS app, and store form submission data in any backend, inc. PHP, ASP.NET Core, and Node.js.
surveyjs.io
featured
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
js-id pg-ulid
3 2
10 58
- -
5.9 0.0
8 months ago over 4 years ago
TypeScript C
Apache License 2.0 -
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

js-id

Posts with mentions or reviews of js-id. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-28.
  • Type-safe, K-sortable, globally unique identifier inspired by Stripe IDs
    19 projects | news.ycombinator.com | 28 Jun 2023
    We have a uuidv7 implementation that we've been using with rocksdb for over a year https://github.com/matrixai/js-id
  • Plan B for UUIDs: double AES-128
    4 projects | news.ycombinator.com | 5 Aug 2022
    We evaluated ULID but we wanted something that is future proof for our decentralised secret sharing system. So we implemented UUIDv7 in TypeScript called `IdSortable` https://github.com/MatrixAI/js-id

    It allows strict monotonic IDs when you provide it the previously generated ID. The resulting data structure is a Uint8Array making it easy to put into binary structures. Can also be used as a key inside any POJO record.

  • Lesser Known PostgreSQL Features
    7 projects | news.ycombinator.com | 9 Nov 2021
    I had reviewed existing UUIDv7 implementations and many were incorrect or had subtle timing bugs.

    We ended up implementing UUIDv7 in our ID generation library https://github.com/MatrixAI/js-id. And we have a number of tests ensuring that it is truly monotonic even across process restarts.

    See IdSortable.

pg-ulid

Posts with mentions or reviews of pg-ulid. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-11-09.
  • Lesser Known PostgreSQL Features
    7 projects | news.ycombinator.com | 9 Nov 2021
    Here's one[1], not actively maintained though.

    [1] https://github.com/edoceo/pg-ulid

  • PostgreSQL UUID vs. Serial vs. Identity
    10 projects | news.ycombinator.com | 31 May 2021
    Yeah, just use a UUID unless the bits to store the UUID really are your driving limitation (they're not), having a UUID that is non-linear is almost always the most straight-forward option for identifying things, for the tradeoff of human readability (though you can get some of that back with prefixes and some other schemes). I'm not going to rehash the benefits that people have brought up for UUIDs, but they're in this thread. At this point what I'm concerned about is just... what is the best kind of UUID to use -- I've recently started using mostly v1 because time relationship is important to me (despite the unfortunate order issues) and v6[0] isn't quite so spread yet. Here's a list of other approaches out there worth looking at

    - isntauuid[1] (mentioned in this thread, I've given it a name here)

    - timeflake[2]

    - HiLo[3][4]

    - ulid[5]

    - ksuid[6] (made popular by segment.io)

    - v1-v6 UUIDs (the ones we all know and some love)

    - sequential interval based UUIDs in Postgres[7]

    Just add a UUID -- this almost surely isn't going to be what bricks your architecture unless you have some crazy high write use case like time series or IoT or something maybe.

    [0]: http://gh.peabody.io/uuidv6/

    [1]: https://instagram-engineering.com/sharding-ids-at-instagram-...

    [2]: https://github.com/anthonynsimon/timeflake

    [3]: https://en.wikipedia.org/wiki/Hi/Lo_algorithm

    [4]: https://www.npgsql.org/efcore/modeling/generated-properties....

    [5]: https://github.com/edoceo/pg-ulid

    [6]: https://github.com/segmentio/ksuid

    [7]: https://www.2ndquadrant.com/en/blog/sequential-uuid-generato...

What are some alternatives?

When comparing js-id and pg-ulid you can also consider the following projects:

ksuid - K-Sortable Globally Unique IDs

typeid - Type-safe, K-sortable, globally unique identifier inspired by Stripe IDs

cuid - Collision-resistant ids optimized for horizontal scaling and performance.

typeid-go - Go implementation of TypeIDs: type-safe, K-sortable, and globally unique identifiers inspired by Stripe IDs

Dapper - Dapper - a simple object mapper for .Net

tbls - tbls is a CI-Friendly tool for document a database, written in Go.

Hasura - Blazing fast, instant realtime GraphQL APIs on your DB with fine grained access control, also trigger webhooks on database events.

resource-id - Developer-friendly k-sortable IDs

postgres-elasticsearch-fdw - Postgres to Elastic Search Foreign Data Wrapper

timeflake - Timeflake is a 128-bit, roughly-ordered, URL-safe UUID.