Please log in to watch this conference skillscast.
Slick 3 is the industry standard library for accessing relational databases in Scala. It provides many benefits, such as a fully asynchronous interface and strong compile-time type-checking, but comes with a cost in terms of complexity. Many experienced Scala developers have difficulty becoming productive with Slick, and beginners often find it to be a significant hurdle.
The session will be divided roughly into four sections:
Getting Started - You will run through the basics of setting up a project and creating a database layer using the Cake pattern. You will define some data tables, configure a database connection, and run some simple queries to test everything is working.
Queries - You will take a close look at Slick's query DSL, including the relationships between tables, columns, and queries. You'll discuss how to filter, project, and join queries to retrieve the desired results.
Actions - You will look at sequencing queries using Slick's Action monad. You will start with simple cases such as running queries one after the other, and proceed to more complex call graphs involving interleaved SQL and Scala code.
Tips and Tricks - You will finish with a set of tips for effective use of Slick, including structuring application code, modelling primary keys, mapping custom data types, and debugging errors at compile and run time.
Code and setup instructions are available in this Github repo.
YOU MAY ALSO LIKE:
- Functional Interpreters and You (SkillsCast recorded in December 2018)
- ScalaCon 2021: November Edition (Online Conference on 2nd - 5th November 2021)
- Journey to the Centre of the JVM (SkillsCast recorded in May 2021)
- Connecting the dots - building and structuring a functional application in Scala (SkillsCast recorded in May 2021)
Workshop: Essential Slick: Hands On With Slick 3
Dave is a developer, trainer, and partner at underscore.io. He has spent over a decade programming, speaking at conferences, and writing books on functional programming.