postgrex VS ecto

Compare postgrex vs ecto and see what are their differences.

ecto

A toolkit for data mapping and language integrated query. (by elixir-ecto)
Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
postgrex ecto
3 14
1,049 5,994
1.0% 0.8%
6.3 9.1
9 days ago 15 days ago
Elixir 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.

postgrex

Posts with mentions or reviews of postgrex. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-01-25.
  • Elixir clustering using Postgres
    4 projects | dev.to | 25 Jan 2024
    Now we can replicate the same behavior in Elixir and Postgrex within IEx (Elixir's interactive shell).
  • TIL: Non standard postgres types in livebook
    2 projects | dev.to | 8 Jan 2023
    But I found a problem when the data type is not supported by postgrex. In this case, you can either have to write a custom postgrex extension like the example here. In postgrex GitHub repo, there are many examples for common data types, but XML is missing there.
  • Realtime: Multiplayer Edition
    13 projects | news.ycombinator.com | 18 Aug 2022
    It sounds like Supabase is pulling out the WAL listening bits into its own library?

    https://supabase.com/blog/supabase-realtime-multiplayer-gene...

    If so, y'all might want to look into: https://github.com/elixir-ecto/postgrex/blob/master/lib/post...

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 postgrex and ecto you can also consider the following projects:

eventstore - Event store using PostgreSQL for persistence

moebius - A functional query tool for Elixir

mariaex - Pure Elixir database driver for MariaDB / MySQL

amnesia - Mnesia wrapper for Elixir.

mongodb_ecto - MongoDB adapter for Ecto

couchdb_connector - A couchdb connector for Elixir

datomex - Elixir driver for the Datomic REST API

riak - A Riak client written in Elixir.

ecto_psql_extras - Ecto PostgreSQL database performance insights. Locks, index usage, buffer cache hit ratios, vacuum stats and more.

shards - Partitioned ETS tables for Erlang and Elixir