MapStruct VS Quill

Compare MapStruct vs Quill and see what are their differences.

Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
MapStruct Quill
24 15
6,797 2,136
1.5% 0.0%
7.8 9.0
28 days ago 6 days ago
Java Scala
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.

MapStruct

Posts with mentions or reviews of MapStruct. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-13.
  • Is .NET just miles ahead or am I delusional?
    4 projects | news.ycombinator.com | 13 Apr 2024
    Currently using .NET and ASP.NET for the API of a project that I'm working on, overall it's a pretty lovely experience, especially with the JetBrains Rider as my IDE. Having worked with Java in the enterprise in the past, it feels like a more focused and sometimes more coherent experience (vs the more decentralized nature of Java), that now thankfully runs fine on Linux as well, don't even need to hope that Mono is good enough anymore.

    Entity Framework Core is great, the way how they fetch related data is straightforwards: https://learn.microsoft.com/en-us/ef/core/querying/related-d...

    I also really like the ability to use split queries, when needed: https://learn.microsoft.com/en-us/ef/core/querying/single-sp...

    You can even scaffold your entity mappings from an existing database and manage database migrations separately (which I feel is a must unless you want to pour hours upon hours into learning yet another JPA-like), it's nice when something like that exists in a given ecosystem: https://blog.jetbrains.com/dotnet/2022/01/31/entity-framewor...

    Some of the stuff in the ecosystem is also really nice, like using ActionBlocks from Dataflow for simple queues and task scheduling is very easy to get started with and pretty pleasant: https://learn.microsoft.com/en-us/dotnet/api/system.threadin...

    Honestly, most of the docs that I've come across are rather pleasant and there's plenty of code examples to be had and even LLMs have enough codebases out there to be trained on and give decent output, in addition to the regular autocomplete in the IDE.

    Even some third party stuff like CsvHelper is really well put together: https://joshclose.github.io/CsvHelper/getting-started/#insta...

    That said, I've had issues where trying to deserialize incoming JSON requests ([FromBody]) lead to the whole object being null, due to it not matching the fields 1:1 or violating some nullability constraint, however that happened without a clear error message or as much as a warning in the logs, which felt insane and wasn't very discoverable. Now I just use JObject as the parameter and deserialize at the top of the controller method.

    I've also run into some ecosystem issues where the OpenAPI codegen was a bit lacking and wouldn't actually generate code that works, but maybe that's because the spec was bad: https://openapi-generator.tech/docs/generators/csharp

    I could also not get AutoMapper (https://docs.automapper.org/en/stable/index.html) working satisfactorily, so for now I'm stuck writing mappers by hand with said autocomplete sometimes doing it for me. There were issues with the runtime being unable to register the mappers or something like that, it was a while ago. Overall it felt like the MapStruct library in Java did everything better: https://mapstruct.org/

    On the other hand, I haven't had any of the Spring Boot DI related headaches (needing @Lazy sometimes) with ASP.NET, things there seem way more straightforwards and you clearly define whether something should be a Singleton or Scoped and the rest... just gets out of your way and works.

    Sadly, there have been very hard to track down cases where I try to do a _dbContext.Add(someEntity) and then when I do a save with just the fields in that one entity changed, the performance absolutely seems to slow down to a crawl. Adding _dbContext.ChangeTracker.AutoDetectChangesEnabled = false seemed to help, but I am still not entirely sure what lead to that behavior, the temp directory on my Linux box also started filling up very rapidly, yet the logs had nothing of use, definitely seems like something I'd need to investigate properly.

    Overall, .NET and its ecosystem is pretty good in most cases. And .NET being used in gamedev is also cool, for those who care about that sort of thing, I wonder why jMonkeyEngine never really took off.

  • Object mapping libraries
    1 project | /r/Python | 18 Sep 2023
    In Java (woof..) we have MapStruct (https://mapstruct.org/). Anything like that in Python? I think maybe the Sqlalchemy mapping in Litestar2 is the closest I've seen.
  • Feedback on a new annotation processor api
    9 projects | /r/java | 20 May 2023
    Done right i can look something like mapstruct for example. But like any other feature you need to get a feeling for when it's a good idea to use it.
  • Mapping in Domain Driven Design sucks
    1 project | /r/javahelp | 6 Feb 2023
    We are using mapstruct but it sucks when you have protobuf :/
  • must known frameworks/libs/tech, every senior java developer must know(?)
    6 projects | /r/java | 9 Dec 2022
    You all beat me to MapStruct and Testcontainers. Honorable mention to RxJava, which I use in Desktop apps.
  • Correct way of exception handling, an optional?
    1 project | /r/javahelp | 30 Nov 2022
    For the mapping, I'm using Mapstruct, I got the instance example from their examples they use INSTANCE as constant.
  • Ask HN: What are your “scratch own itch” projects?
    34 projects | news.ycombinator.com | 13 Nov 2022
  • What next Springboot?
    1 project | /r/javahelp | 1 Oct 2022
    Now update your code so that no entities are passed to/from the domain layer and that no objects are passed to/from the domain layer. You'll look at me as though I'm nuts, but you will thank me later. Look at things like http://immutables.github.io/ and https://mapstruct.org/
  • Using MapStruct and Lombok with Inheritance
    1 project | dev.to | 22 Sep 2022
    When my pairing partner and I ran into this use case, we were initially stumped. Even our combined Google Fu efforts were not turning up a good solution. However, we eventually discovered a PR for MapStruct that seemed to be the solution to our issues! But, of course, if it were that simple, I would not be writing this now. The SubClassMapping annotation provided by that PR, while quite helpful, requires specific Mapping annotations for every field on the subclass. We wanted a more elegant solution.
  • We released a new version of ShapeShift (0.6.0) - A lightweight, modular, performant and extensible object mapping library
    2 projects | /r/java | 6 Sep 2022
    Just use MapStruct...

Quill

Posts with mentions or reviews of Quill. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-02.
  • Dear Sir, You Have Built a Compiler (2022)
    1 project | news.ycombinator.com | 17 Aug 2023
    https://github.com/zio/zio-quill

    This library does exactly what you prescribe. Pretty sure under the hood it's using macros with string templates

  • Sketch of a Post-ORM
    14 projects | news.ycombinator.com | 2 Jun 2023
  • Why use Spark?
    1 project | /r/dataengineering | 10 Jan 2023
    But I can connect to Postgress with something like Quill and run sophisticated queries to fetch data. Which then got me thinking, what is the difference between using Spark to connect to the database and using something like Quill or your normal pure JDBC driver?
  • What's the point of opaque type aliases (and are they actually sound)?
    1 project | /r/scala | 26 Nov 2022
    Just as an example, say you are using quill ( https://getquill.io/ ) to query your database.
  • I want to move to Scala 3, but I'm not sure what libraries to use
    11 projects | /r/scala | 31 Aug 2022
  • Query DSL in Scala ?
    1 project | /r/scala | 24 Feb 2022
    I think Quill is the closest to your request: https://github.com/zio/zio-quill
  • Doobie tutorial: databases and pure FP in Scala
    1 project | /r/scala | 21 Jan 2022
    If this still looks like too much hassle, you can always go a bit higher-level and use something like Quill, which is also a powerful approach that uses a different, more ORM-like style.
  • Ask HN: What cutting-edge technology do you use?
    5 projects | news.ycombinator.com | 25 Dec 2021
    I'm using it mostly for full-stack web development with ScalaJS (https://www.scala-js.org) in the frontend (https://outwatch.github.io/docs/readme.html) and in the backend with AWS lambdas.

    The ecosystem is currently in the process of porting all the libraries to Scala 3. So if you're new to Scala, I'd recommend to start with Scala 2, which is rock-solid and already very powerful.

    I never worked with SQLAlchemy. But on the scala database side, popular libraries are Doobie (https://tpolecat.github.io/doobie) and Quill (https://getquill.io). Keep in mind that these are for Scala on the JVM. On the ScalaJS side I'm using the javascript library pg. But I'd like to try if it works well with Prisma soon.

    The nice thing about ScalaJS is, that you can use Javascript libraries. And if there are typescript facades, then you can transpile these to Scala and use them in a type safe way (https://scalablytyped.org).

  • Fp libraries that target scala 3 exclusively?
    5 projects | /r/scala | 22 Nov 2021
    I know that libraries like Scodec and shapeless were rewritten practically from scratch for Scala 3, taking advantage of the next syntax and internals, as well as protoquill - a Scala 3 implementation of Quill.
  • Best Scala framework / libraries out there ?
    4 projects | /r/scala | 31 Oct 2021
    Akka HTTP, Cats, Quill, ninny, Monix Observable, mill.

What are some alternatives?

When comparing MapStruct and Quill you can also consider the following projects:

ModelMapper - Intelligent object mapping

Slick - Slick (Scala Language Integrated Connection Kit) is a modern database query and access library for Scala

JMapper Framework - Elegance, high performance and robustness all in one java bean mapper

doobie - Functional JDBC layer for Scala.

Orika - Simpler, better and faster Java bean mapping framework

ScalikeJDBC - A tidy SQL-based DB access library for Scala developers. This library naturally wraps JDBC APIs and provides you easy-to-use APIs.

Dozer - Dozer is a Java Bean to Java Bean mapper that recursively copies data from one object to another.

Phantom - Schema safe, type-safe, reactive Scala driver for Cassandra/Datastax Enterprise

Selma - Selma Java bean mapping that compiles

Clickhouse-scala-client - Clickhouse Scala Client with Reactive Streams support

record-builder - Record builder generator for Java records

zio-protoquill - Quill for Scala 3