What does the <> operator do in Slick?

后端 未结 3 1211
甜味超标
甜味超标 2020-12-09 03:40

I was walking through the documentation of Slick to setup a quick working prototype.

In the Mapped Tables section I see a <> operator in the examp

3条回答
  •  春和景丽
    2020-12-09 04:09

    The <> operator defines a relation between a Row in the Table and a case class.

    case class User(id: Option[Int], first: String, last: String)
    
    ROW            |id             | first        | last        |
    

    So the data first is taken out of the Tabels as an n-tuple (left side of <>) and then transformed to the case class (right side of <>).

    To make the transformation of the case class work one needs two kinds of methods:

    Row to n-tuple to case class.

    scala> User.tupled
    res6: ((Option[Int], String, String)) => User = 
    

    So this function can create a User when given a triple (Option[Int], String, String) as an argument.

    case class to n-tuple to be written in DB.

    scala> User.unapply _
    res7: User => Option[(Option[Int], String, String)] = 
    

    This function provides the functionality with the other way round. Given a user it can extract a triple. This pattern is called an Extractor. Here you can learn more about this: http://www.scala-lang.org/old/node/112

提交回复
热议问题