clientdb VS RxDB

Compare clientdb vs RxDB and see what are their differences.

clientdb

ClientDB is an open source in-memory database for enabling real-time web apps. (by clientdb)
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
clientdb RxDB
3 46
639 20,747
0.0% -
0.0 9.9
about 1 year ago 2 days ago
TypeScript TypeScript
Apache License 2.0 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.

clientdb

Posts with mentions or reviews of clientdb. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-10-06.
  • The Future of the Web Is on the Edge
    7 projects | news.ycombinator.com | 6 Oct 2022
    Replicache (https://replicache.dev/) and clientdb (https://clientdb.dev/) are the only productized versions of this architecture I'm aware of (please do let me know if anyone is aware of others!).

    But the architecture itself has been used successfully in a bunch of apps, most notable of which is probably Linear (https://linear.app/docs/offline-mode, I remember watching an early video of their founder explaining the architecture in more detail but I can't seem to find it anymore).

    Basically the way authorization works is you define specific mutations that are supported and allowed, with a client-side and server-side implementation. The client side gets applied optimistically and then sync'ed and ran on the server, which applies authorization rules and detects and handles conflicts, which can result in client state getting rolled back. Replicache has a good writeup here: https://doc.replicache.dev/how-it-works#the-big-picture

  • TinyBase v2.0: “the reactive data store for local-first apps”
    5 projects | news.ycombinator.com | 16 Sep 2022
    This looks really cool, love seeing more innovation in this space!

    At first glance this seems to be mostly targeted towards single-user apps where each user would have their own database that can be sync'ed to a remote server, but still isolated from data for other users, similar to the CouchDB+PouchDB model?

    At least it looks that way since I couldn't see anything around authorization and conflict resolution. Not that there's anything wrong with focusing on this use case, a lot of apps can function perfectly fine this way.

    A few other interesting new players:

    https://replicache.dev/

    https://clientdb.dev/

  • ClientDB
    1 project | /r/devopspro | 7 Aug 2022

RxDB

Posts with mentions or reviews of RxDB. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-17.
  • Ask HN: How Can I Make My Front End React to Database Changes in Real-Time?
    8 projects | news.ycombinator.com | 17 Apr 2024
    I'm interested in this problem also!

    I think there is a large overlap with projects that market/focus on offline-first experiences.

    AFAIK this problem can be solved by:

    1) Considering a client-side copy of the database that gets synced with the remote DB. This is an approach [PowerSync](https://www.powersync.com/) and [ElectricSql](https://electric-sql.com/) and [rxdb](https://rxdb.info/) take!

  • You can't leak users' data if you don't hold it
    2 projects | news.ycombinator.com | 30 Mar 2024
    Hey, after I posted that, I went and gave a second look online to see if I could find something that would allow me to develop a local-first app with offline persistence and syncing capabilities.

    I ended up finding some possibilities out there that could potentially help me build stuff. One of them is RxDB [1], which offers WebRTC syncing - you'd still need a signaling server, I suppose, but all sensitive information could be synced E2E-encrypted via WebRTC.

    Then there's CRDT's [2], which is a universe that turned out to have multiple possibilities that match (at least partially) my needs. In particular, the next thing I want to take a look at is cr-sqlite [3], which might be just thing I needed to kick-off some side-projects.

    I'm posting here cause I just found some hope of not needing to build a traditional client-server app and having to deal with all the hassle involved in securing a server (and with fear that my efforts could be not good enough), and I thought someone else could benefit from getting to know these things.

    [1] https://rxdb.info/

  • SignalDB: Bringing Meteor-Like Reactivity to the Modern Age
    1 project | dev.to | 26 Oct 2023
    About a year ago, I discovered a cool offline-first framework called RxDB. Initially, I thought that on the frontend side, this was exactly what I had been searching for over the past years. After tinkering around and even using it in production for some time, I realized that it wasn't well-suited for my intended use. RxDB was initially created as an RxJS layer for PouchDB with a server replication interface. Over time, other storage types besides PouchDB were introduced (e.g., IndexedDB, SQLite) and the replication interface became more sophisticated. The replication interface is really cool and exactly what I wanted. The biggest problem I have with RxDB is that it is so tightly coupled with RxJS. While RxJS is technically very powerful, it offers a dreadful developer experience. It's really hard to understand at first and integrating it into an existing codebase, which isn't using RxJS, is tedious.
  • Show HN: ElectricSQL, Postgres to SQLite active-active sync for local-first apps
    10 projects | news.ycombinator.com | 20 Sep 2023
    Congrats to the team. Once I’ve tried https://rxdb.info/ and it wasn’t funny at all to do the remote replication (PG) and to deal with conflicts. I do need to check this out!
  • What is the best DB for offline-first?
    3 projects | /r/reactnative | 14 Sep 2023
    RxDB (Open Source but paid plugins)
  • RxDB VS signaldb - a user suggested alternative
    2 projects | 1 Aug 2023
  • RxDB: The Local Database for JavaScript Applications
    1 project | news.ycombinator.com | 12 Jun 2023
  • RxDB - The local Database for JavaScript Applications
    1 project | /r/node | 12 Jun 2023
  • Best offline&local database to use with electron?
    2 projects | /r/electronjs | 11 Jun 2023
  • Offline First
    1 project | news.ycombinator.com | 18 May 2023

What are some alternatives?

When comparing clientdb and RxDB you can also consider the following projects:

tinybase - The reactive data store for local‑first apps.

WatermelonDB - 🍉 Reactive & asynchronous database for powerful React and React Native apps ⚡️

TypeORM - ORM for TypeScript and JavaScript. Supports MySQL, PostgreSQL, MariaDB, SQLite, MS SQL Server, Oracle, SAP Hana, WebSQL databases. Works in NodeJS, Browser, Ionic, Cordova and Electron platforms.

PouchDB - :koala: - PouchDB is a pocket-sized database.

Prisma - Next-generation ORM for Node.js & TypeScript | PostgreSQL, MySQL, MariaDB, SQL Server, SQLite, MongoDB and CockroachDB

ObjectBox Java (Kotlin, Android) - Java and Android Database - fast and lightweight without any ORM

Sequelize - Feature-rich ORM for modern Node.js and TypeScript, it supports PostgreSQL (with JSON and JSONB support), MySQL, MariaDB, SQLite, MS SQL Server, Snowflake, Oracle DB (v6), DB2 and DB2 for IBM i.

SyncedStore - SyncedStore CRDT is an easy-to-use library for building live, collaborative applications that sync automatically.

Mongoose - MongoDB object modeling designed to work in an asynchronous environment.

MikroORM - TypeScript ORM for Node.js based on Data Mapper, Unit of Work and Identity Map patterns. Supports MongoDB, MySQL, MariaDB, MS SQL Server, PostgreSQL and SQLite/libSQL databases.

uuid-mongodb - 📇 Generates and parses MongoDB BSON UUIDs

supabase - The open source Firebase alternative.