Quill VS Chimney

Compare Quill vs Chimney 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
Quill Chimney
15 13
2,136 1,106
0.0% 2.3%
9.1 9.7
7 days ago about 7 hours ago
Scala 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.

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.

Chimney

Posts with mentions or reviews of Chimney. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-02-24.
  • Chimney 0.8.0 (stable) released
    1 project | /r/scala | 13 Oct 2023
  • Chimney 0.8.0-M1 with the initial support for Scala 3
    1 project | /r/scala | 5 Aug 2023
  • Chimney 0.8.0-M1 – type mapping library for Scala released for Scala 3
    1 project | news.ycombinator.com | 3 Aug 2023
  • ORM in Scala
    1 project | /r/scala | 3 Apr 2023
    But yeah, I wonder if using a tool for case classes conversion like https://github.com/scalalandio/chimney would help in managing those ADT hierarchies for DB/business logic/web layer/etc.
  • Chimney 0.7.0 released
    2 projects | /r/scala | 24 Feb 2023
    Hello, if you have some nice examples could you please check if it's something that would fit any of issues planned for 0.7.1 or create a new one?
  • Output object with Circe with sealed trait + case classes adds sealed trait block
    1 project | /r/scala | 13 Nov 2022
    Perhaps, https://github.com/scalalandio/chimney would leverage it.
  • Smithy4s 0.15.0, now with Smithy 2.0 support
    2 projects | /r/scala | 18 Aug 2022
    Thankfully, there are some solutions that can help reduce the boilerplate of these manual conversions. For instance, chimney : https://scalalandio.github.io/chimney/
  • Is it possible to get runnable generated scala code from a macro (chminey to be specific)?
    2 projects | /r/scala | 20 Jan 2022
    I want to upgrade one project to Scala 3.1, but I'm using the macro heavy chimney (https://github.com/scalalandio/chimney) to reduce the boilerplate, which is not available for Scala 3 yet. My idea was to copy and paste the code that chimney generates on 2.13, and after that uncomment the uses of chimney for now.
  • From ES6 to Scala: Basics
    9 projects | news.ycombinator.com | 20 Jan 2022
    In my $dayjob we originally used Scala, but I pushed for a couple of new services to be written in TypeScript/Node as it was really hard to hire Scala developers. I'd say it worked well, we even took a somewhat functional approach to building things. We tried fp-ts but that was a bit hardcore (when you are trying to hire TypeScript developers who don't know functional programming), so just built Either and Option types which provided 99% of what we needed.

    There are still a few things I miss though:

    * Pattern matching and exhaustive checking. Using a switch statement it is possible to define a function that can emulate the compile-time exhaustive checking, but it's still rather weak compared to what you can do in Scala.

    * Implicits. Being able to define something that can convert say a UUID to a String or vice versa automatically just feels like magic, especially when dealing with data from third party systems.

    * Compiler macros and metaprogramming. It enables tools like Chimney (https://scalalandio.github.io/chimney/) to be built, which I don't think are possible with TypeScript right now.

  • Scala Type Classes from Scratch
    1 project | /r/scala | 18 Jun 2021
    Converting between these classes can add some boilerplate, but luckily there are libraries like https://github.com/scalalandio/chimney that make it much easier.

What are some alternatives?

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

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

Shapeless - Generic programming for Scala

doobie - Functional JDBC layer for Scala.

Monocle - Optics library for Scala

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

Lamma - Lamma schedule generator for Scala is a professional schedule generation library for periodic schedules like fixed income coupon payment, equity deravitive fixing date generation etc.

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

Enumeratum - A type-safe, reflection-free, powerful enumeration implementation for Scala with exhaustive pattern match warnings and helpful integrations.

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

Scalaz - Principled Functional Programming in Scala

zio-protoquill - Quill for Scala 3

Quicklens - Modify deeply nested case class fields