ddl-diff VS trustfall

Compare ddl-diff vs trustfall and see what are their differences.

ddl-diff

Generates SQL migrations by parsing and diffing DDL (by cbowdon)

trustfall

A query engine for any combination of data sources. Query your files and APIs as if they were databases! (by obi1kenobi)
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
ddl-diff trustfall
1 24
2 2,273
- -
10.0 9.2
over 6 years ago 9 days ago
Scala Rust
GNU General Public License v3.0 only 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.

ddl-diff

Posts with mentions or reviews of ddl-diff. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-12-29.
  • PRQL a simple, powerful, pipelined SQL replacement
    19 projects | news.ycombinator.com | 29 Dec 2022
    So, after digging about in the docs, I found the Best Practices[0] page which lays out what you describe. I was disappointed to find it is just using idempotent creation statements for procedures and views and putting them all in files that are re-run on each migration step-along with each new roll forward migration-so that new versions of these logic objects replace any old ones. This is not exactly something that liquidbase provides, should be easily replicatable, and I was hoping it'd do diffs to provide similar experience on tables as well.

    After some web searching, I came across a project[1] that's trying to do what I describe but it appears to be dead. I'm surprised that migration tools (that I looked through) don't already support such a basic approach that I suspect I'm missing something obvious. Some fundamental block in how SQL works or maybe it doesn't work that well in practice for, in concept, it sounds easy to script using what they call a shadow db and `pg_diff`.

    [0]: https://docs.liquibase.com/concepts/bestpractices.html

    [1]: https://github.com/cbowdon/ddl-diff

trustfall

Posts with mentions or reviews of trustfall. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-02-20.
  • Planner programming blows my mind
    4 projects | news.ycombinator.com | 20 Feb 2024
    Pleasantly surprised to see Predrag show up as a reviewer, but at the same time not at all surprised:

    - The [Firebase technical screen](https://startupandrew.com/posts/how-firebase-interviewed-sof...) would have been much easier with something like this, as it was Just Another Optimization Problem™. Part of me wants to try it again with Picat!

    - He's doing other very interesting things with programming languages, e.g.: https://github.com/obi1kenobi/trustfall

  • Ask HN: Who wants to be hired? (December 2023)
    26 projects | news.ycombinator.com | 1 Dec 2023
    Email: [email protected]

    Hi, I'm u9g. I'm looking for an internship for either this winter (in a few weeks) or a summer internship!

    Some things I've done:

    I integrated a [query engine for lints](https://github.com/obi1kenobi/trustfall) (and contributed optimizations) into [OXC](https://github.com/oxc-project/oxc) (a new Rust-based Javascript Linter).

    I wrote [several](https://github.com/u9g/money-lens) [toy](https://github.com/u9g/quickquestion/tree/main/extension) languages and syntax highlighting for them.

    I also wrote a [js-to-scheme transpiler](https://github.com/u9g/js2scheme/blob/main/example.js).

    Happy to work on things compiler or database oriented, but also happy to learn something new!

  • Semver violations are common, better tooling is the answer
    7 projects | news.ycombinator.com | 7 Sep 2023
    If you'd like to dig deeper, here are some links:

    - cargo-semver-checks: https://github.com/obi1kenobi/cargo-semver-checks

    - Trustfall query engine, which powers cargo-semver-checks: https://github.com/obi1kenobi/trustfall

    - Trustfall playground, where you can query Rust library APIs in your browser -- for example, "which structs in `itertools` are importable by more than one path": https://play.predr.ag/rustdoc#?f=2&q=*3-Structs-importable-f...

    - 10min conference talk on Trustfall: https://www.hytradboi.com/2022/how-to-query-almost-everythin...

    I'm also giving a talk at P99 CONF in a few months about how Trustfall's new optimizations API made cargo-semver-checks over 2300x faster: https://twitter.com/PredragGruevski/status/16893002495908003...

  • Cargo-semver-checks: Scan your Rust crate for semver violations
    3 projects | news.ycombinator.com | 8 Jul 2023
    No worries!

    Trustfall is even more general than semver actually, one can use it to query any data source -- even HN itself:

    https://play.predr.ag/HackerNews

    Here's a link to that project if you'd like to check it out:

    https://github.com/obi1kenobi/trustfall

    I gave a 10min conference talk on it last year titled "How to query (almost) everything"

    https://www.hytradboi.com/2022/how-to-query-almost-everythin...

  • We created Taxi, and why we felt the need for Another Schema Language
    2 projects | news.ycombinator.com | 16 May 2023
    I've had my eye on Taxi for a while, and it's neat! I agree that the problems it aims to solve are real and painful in real life.

    In my experience, I'm not sure people care about schemas or schema languages — they are just implementation details best left under the hood. This is why in my own work, I started on the query end of the spectrum instead.

    This is why I built Trustfall, a query engine able to query any data source: DBs, APIs, files like PDF, CSV, or JSON, or any combination of those.

    GitHub: https://github.com/obi1kenobi/trustfall

    Playground showing the query "which GitHub/Twitter users comment on HackerNews stories about OpenAI?": https://play.predr.ag/hackernews#?f=1&q=IyBDcm9zcyBBUEkgcXVl...

  • cargo-semver-checks v0.20 and Trustfall v0.4 released — semver-check up to 2354x faster
    3 projects | /r/rust | 24 Apr 2023
  • DuckDB: Querying JSON files as if they were tables
    9 projects | news.ycombinator.com | 3 Mar 2023
  • Speeding up Rust semver-checking by over 2000x
    2 projects | /r/rust | 15 Feb 2023
    Here's an example adapter for querying RSS/Atom feeds. Here's an example adapter for querying the HackerNews APIs. Both projects also include a schema and example queries which you can run.
  • Trustfall: How to Query (Almost) Everything
    1 project | /r/patient_hackernews | 8 Feb 2023
    1 project | /r/hackernews | 8 Feb 2023

What are some alternatives?

When comparing ddl-diff and trustfall you can also consider the following projects:

cargo-semver-checks - Scan your Rust crate for semver violations.

postgrest - REST API for any Postgres database

prql-query - Query and transform data with PRQL

cargo-semver-checks-action - A GitHub Action for running cargo-semver-checks

FunSQL.jl - Julia library for compositional construction of SQL queries

join-monster - A GraphQL to SQL query execution layer for query planning and batch data fetching.

normconf2022

graphql-java - GraphQL Java implementation

prql - PRQL is a modern language for transforming data — a simple, powerful, pipelined SQL replacement

dgs-framework - [Moved to: https://github.com/Netflix/dgs-framework]

liquibase - Main Liquibase Source

genql - Type safe TypeScript client for any GraphQL API