Slick 2.0 - update two or more columns
Asked Answered
A

2

0

I know I can update two columns in Slick 2.0 with:

val q = for (user <- Users if user.id === id) yield (user.name, user.city)
q.update((newName, newCity))

But I've seen something like this working as well which is IMO much nicer syntax:

Users.filter(_.id === id).map(u => u.name ~ u.city).update(newName, newCity)

This gives me the following error:

value ~ is not a member of shortcut.db.Tables.profile.simple.Column

I have imported PostgresDriver.simple._ and I just can't figure out why. I also use the code generator.

Thanks in advance!

Ancona answered 12/6, 2014 at 0:40 Comment(0)
T
2

That is because the ~ method was moved out of the normal import scope for Slick 2.0. You can either use a tuple, just as is:

Users.filter(_.id === id).map(u => (u.name, u.city)).update((newName, newCity))

or import the necessary TupleMethods object:

import scala.slick.util.TupleMethods._
Users.filter(_.id === id).map(u => u.name ~ u.city).update((newName, newCity))
Trapp answered 12/6, 2014 at 2:25 Comment(0)
B
1

In addition to Sean Vieira's answer:

for (user <- Users if user.id === id) yield (user.name, user.city)

is just syntactic sugar for

Users.filter(_.id === id).map(u => (u.name, u.city))

and that's not Slick-specific, it's the Scala compiler that desugars this for Scala-collections, for Slick, for anything.

Brahms answered 12/6, 2014 at 10:4 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.