tidyquery VS ecto

Compare tidyquery vs ecto and see what are their differences.

tidyquery

Query R data frames with SQL (by ianmcook)

ecto

A toolkit for data mapping and language integrated query. (by elixir-ecto)
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
tidyquery ecto
2 14
167 5,998
- 0.9%
0.0 9.0
over 1 year ago 2 days ago
R Elixir
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.

tidyquery

Posts with mentions or reviews of tidyquery. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-03-02.
  • Can "dplyr" code automatically be converted to SQL code?
    1 project | /r/rstats | 15 Sep 2021
    tidyquery
  • ClickHouse as an alternative to Elasticsearch for log storage and analysis
    13 projects | news.ycombinator.com | 2 Mar 2021
    > SQL is a perfect language for analytics.

    Slightly off topic, but I strongly agree with this statement and wonder why the languages used for a lot of data science work (R, Python) don't have such a strong focus on SQL.

    It might just be my brain, but SQL makes so much logical sense as a query language and, with small variances, is used to directly query so many databases.

    In R, why learn the data.tables (OK, speed) or dplyr paradigms, when SQL can be easily applied directly to dataframes? There are libraries to support this like sqldf[1], tidyquery[2] and duckdf[3] (author). And I'm sure the situation is similar in Python.

    This is not a post against great libraries like data.table and dplyr, which I do use from time to time. It's more of a question about why SQL is not more popular as the query language de jour for data science.

    [1] https://cran.r-project.org/web/packages/sqldf/index.html

    [2] https://github.com/ianmcook/tidyquery

    [3] https://github.com/phillc73/duckdf

ecto

Posts with mentions or reviews of ecto. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-03-14.
  • Idempotent seeds in Elixir
    2 projects | dev.to | 14 Mar 2024
    To ruin the party, deterministic UUID generation is exactly what UUID v5 is designed for. And since Ecto does not validate UUIDs against their specs, you might as well use uuid again and do:
  • Ecto: A toolkit for data mapping and language integrated query
    1 project | news.ycombinator.com | 21 Jul 2023
  • Sketch of a Post-ORM
    14 projects | news.ycombinator.com | 2 Jun 2023
    To me this looks a lot like ecto https://github.com/elixir-ecto/ecto

    Is there a significant difference?

  • Dependency inversion on Elixir using Ports and Adapters design pattern
    2 projects | dev.to | 10 Jan 2023
    Ecto database driver use-case
  • Do I need to use Elixir from Go perspective?
    5 projects | /r/elixir | 9 Jan 2023
    When it comes to building microservices, Go has the advantage of being easier to deploy and tighter integration with gRPC. On the other hand, Elixir will provide a more expressive layer to communicate with the database through Ecto.
  • Ask HN: Is my software stack choice sound?
    3 projects | news.ycombinator.com | 3 Aug 2022
    May I ask why CouchDB though? Is it for the offline support?

    Phoenix comes with its own database tool called Ecto[0] which is excellent, and it uses Postgres by default. If you're not intended to leverage CouchDB for offline support you should go Postgres without a second thought.

    That said, I'm also curious about how to implement offline support with Phoenix in a nice and trivial way.

    [0] https://github.com/elixir-ecto/ecto

  • Do it to learn Elixir
    2 projects | dev.to | 15 Jun 2022
    The best would be to set aside at least 40 minutes of study a day. Being 20 minutes focused on the core of the language, solving problems and a website that can help you a lot and exercism. Another 20 minutes some of the core frameworks like: Phoenix, Ecto, Enum
  • Using CQRS in a simple Phoenix API with Commanded
    7 projects | dev.to | 10 May 2022
    This is a testiment to the value and productivity of Phoenix, but the resulting code is just basic CRUD. The views are tied 1:1 with their database-backed Ecto schemas. One thing to note is that Phoenix generates DDD-style contexts. This is unlike Rails, which would produce a typical ActiveRecord sprawl: bloated models directly being accessed and lazily queried across the entire application.
  • How to Use Macros in Elixir
    3 projects | dev.to | 2 Nov 2021
    Ecto uses prewalk to count the number of interpolations within a given expression.
  • Dynamic Queries in Ecto (Elixir Lang)
    3 projects | news.ycombinator.com | 15 Sep 2021
    I've used my share of data access libraries and patterns (e.g. hibernate, activerecord, ecto, ...). The only time I've been happy is when I use raw SQL for non-dynamic SQL and a lightweight query builder for everything else.

    I feel like I always run into some thing that at best isn't intuitive to express/read and at worse, cannot be expressed. If I remember correctly, when I was learning Elixir/Ecto, https://github.com/elixir-ecto/ecto/issues/1616 issue and the lack of lateral join support caused me issues.

    Want to create a user?

    "insert into users (id, name, status) values ($1, $2, $3)"

    Our query builder takes pretty raw SQL fragments:

        q = Query.new()

What are some alternatives?

When comparing tidyquery and ecto you can also consider the following projects:

duckdf - 🦆 SQL for R dataframes, with ducks

moebius - A functional query tool for Elixir

clickhousedb_fdw - PostgreSQL's Foreign Data Wrapper For ClickHouse

postgrex - PostgreSQL driver for Elixir

meilisearch-js-plugins - The search client to use Meilisearch with InstantSearch.

amnesia - Mnesia wrapper for Elixir.

tidyquant - Bringing financial analysis to the tidyverse

couchdb_connector - A couchdb connector for Elixir

tidyverse - Easily install and load packages from the tidyverse

datomex - Elixir driver for the Datomic REST API

tidylog - Tidylog provides feedback about dplyr and tidyr operations. It provides wrapper functions for the most common functions, such as filter, mutate, select, and group_by, and provides detailed output for joins.

riak - A Riak client written in Elixir.