mongo4cats
Quill
Our great sponsors
- CodiumAI - TestGPT | Generating meaningful tests for busy devs
- SonarLint - Clean code begins in your IDE with SonarLint
- InfluxDB - Access the most powerful time series database as a service
- ONLYOFFICE ONLYOFFICE Docs — document collaboration in your environment
mongo4cats | Quill | |
---|---|---|
1 | 13 | |
69 | 2,121 | |
- | 0.6% | |
8.9 | 9.0 | |
5 days ago | 4 days ago | |
Scala | Scala | |
Apache License 2.0 | Apache License 2.0 |
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.
mongo4cats
-
I want to move to Scala 3, but I'm not sure what libraries to use
For MongoDB use Mongo4cats with ZIO https://github.com/Kirill5k/mongo4cats
Quill
- I want to move to Scala 3, but I'm not sure what libraries to use
-
Ask HN: What cutting-edge technology do you use?
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?
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 ?
Akka HTTP, Cats, Quill, ninny, Monix Observable, mill.
-
Ideas for a Scala 3 MapStruct library?
https://getquill.io/#docs (Look under SCHEMA).
-
Ask HN: What stack would you use to build a CRUD web app on the JVM today?
I would use it at work because I know it. There are a LOT of libraries in Scala for HTTP up to database stuff, and it really depends on what kind of ecosystem you're walking into:
* Scala as Python: https://github.com/com-lihaoyi/cask, maybe https://github.com/getquill/quill
* Scala as Haskell: HTTP4s, https://tpolecat.github.io/doobie/
* Scala as Rails: Play
Play is the closest thing to Rails-like CRUD productivity IMO, and honestly for CRUD most times I would like to write as little code as possible and just get it done, even using low/no-code solutions (postgrest, hasura, htmx), but that wasn't the question :)
-
[Debate] Is type level programming useful?
quill is uses type level programming. It allows for the pre-computation of SQL queries during compilation, and you can inspect what queries will look like, whilst you code without, running anything.
-
From First Principles: Why Scala?
I've heard that too but I think there are at least efforts to support Scala 3.
Having said that I think Quill looks nicer (https://getquill.io/) if you want a DSL like that.
What are some alternatives?
Slick - Slick (Scala Language Integrated Connection Kit) is a modern database query and access library for Scala
doobie - Functional JDBC layer 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.
Phantom - Schema safe, type-safe, reactive Scala driver for Cassandra/Datastax Enterprise
zio-protoquill - Quill for Scala 3
Squeryl - A Scala DSL for talking with databases with minimum verbosity and maximum type safety
Clickhouse-scala-client - Clickhouse Scala Client with Reactive Streams support
PostgreSQL and MySQL async
deequ - Deequ is a library built on top of Apache Spark for defining "unit tests for data", which measure data quality in large datasets.
SwayDB - Persistent and in-memory key-value storage engine for JVM that scales on a single machine.
dotty - The Scala 3 compiler, also known as Dotty.
AnormCypher - Neo4j Scala library based on Anorm in the Play Framework