你的问题的根源是超载apply
def.
tupled
不适用于case class
's with less than 2 parameters
or overloaded apply
.
就光滑而言*
(或全部)映射和<>
关心的是,它应该是这样的,
def * = (tupleMember1, tupleMember2, ...) <> (func1, func2)
这样,
-
func1
接受那个元组(tupleMember1, tupleMember2, ...)
作为输入并返回映射类/案例类的实例。
-
func1
获取映射类/案例类的实例并返回该元组(tupleMember1, tupleMember2, ...)
.
所以你可以提供任何满足这些要求的功能。
case class User(id: Long, firstName: String, lastName: String, mobile: Long, email: String)
object User {
private val seq = new AtomicLong
def apply(firstName: String, lastName: String, mobile: Long, email: String): User = {
User(seq.incrementAndGet(), firstName, lastName, mobile, email)
}
def mapperTo(
id: Long, firstName: String,
lastName: String, mobile: Long, email: String
) = apply(id, firstName, lastName, mobile, email)
}
class UserTableDef(tag: Tag) extends Table[User](tag, "user") {
def id = column[Long]("id", O.PrimaryKey, O.AutoInc)
def firstName = column[String]("first_name")
def lastName = column[String]("last_name")
def mobile = column[Long]("mobile")
def email = column[String]("email")
override def * =
(id, firstName, lastName, mobile, email) <> ((User.mapperTo _).tupled, User.unapply)
}