odoyle-rules VS RxDB

Compare odoyle-rules vs RxDB and see what are their differences.

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
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
odoyle-rules RxDB
10 46
517 20,747
- -
6.2 9.9
7 months ago 4 days ago
Clojure TypeScript
The Unlicense 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.

odoyle-rules

Posts with mentions or reviews of odoyle-rules. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-05-09.
  • Use of Posh for frontend development?
    9 projects | /r/Clojure | 9 May 2023
    If you're going down this route I'd second the recommendation for O'Doyle Rules. (Haven't used it since I switched away from SPAs altogether, but when I was investigating stuff in that space, O'Doyle appeared to be taking the "correct approach" from what I could tell.)
  • [Blog] The Web Before Teatime
    3 projects | /r/Clojure | 17 Jan 2023
    That's what this tiny library does https://github.com/oakes/odoyle-rules
  • [ANN] odoyle-rules 1.0.0
    1 project | /r/Clojure | 14 Oct 2022
  • Ideas for DataScript 2
    6 projects | news.ycombinator.com | 14 Aug 2022
    Reactive updates is the big one, in my opinion. DataScript is a triumph and arguably is the reason why so many note-taking tools (Roam, Athens, Logseq, etc) are written in Clojure. But there are so many cases where it would be nice to react when some set of entities is changed.

    I think what we need is to figure out how to combine DataScript with a rules engine. I'm wrote a rules engine and made a writeup that compares the two together: "Using O'Doyle Rules as a poor man's DataScript" https://github.com/oakes/odoyle-rules/blob/master/bench-src/...

    Subscribing to individual entities is nice but with a rules engine you have so much more fine-grained control over your reactions. And with the RETE algorithm this can be done efficiently. Most libraries in this space just ignore it and make their own ad-hoc solution -- an informally-specified, bug-ridden, slow implementation of half of a rules engine.

  • UIs Are Streaming Dags
    6 projects | news.ycombinator.com | 30 Apr 2022
  • Datalog for HTTP APIs
    3 projects | /r/Clojure | 27 Apr 2022
    Odoyle-rules lets you write rules (forwards chaining) engine that you can run on client and server. There are a couple ways you can twist that idea to achieve a more unified system.
  • Next Web
    2 projects | /r/Clojure | 30 Apr 2021
    I suspect it'd be too much of a mismatch to be useful, but i haven't thought about it enough. I think a more promising idea is to try implementing a database with o'doyle. I wrote about my first attempt here: Using O'Doyle Rules as a poor man's DataScript Right now it would be too inefficient for large data sets because it has to constantly rebuild its index but i think with some small changes i could improve that and basically turn o'doyle into a tool for creating databases that come with reactivity for free.
  • O'Doyle Rules - a Clojure rules engine for the best of us
    6 projects | /r/Clojure | 10 Feb 2021
    No doubt there's a runtime cost in joining the facts together, so naturally a system that lumps facts together into records (like clara) will have to do fewer joins, and should be faster. I figured out that i could at least deduplicate my joins with derived facts as i explained here, which ended up being a really big perf boost. But there's still a tradeoff, and one where almost everyone should favor flexibility, i think.

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 odoyle-rules and RxDB you can also consider the following projects:

pararules - A Nim rules engine

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

paranim_examples

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.

asami - A flexible graph store, written in Clojure

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

posh - A luxuriously simple and powerful way to make front-ends with DataScript and Reagent in Clojure.

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

spork - Spoon's Operations Research Kit

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

missionary - A functional effect and streaming system for Clojure/Script

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.