Ожидается несоответствие типов NotInferedR - PullRequest
0 голосов
/ 20 марта 2019

Я пытаюсь получить базовое работающее доказательство Slick, но получаю ошибку несоответствия типов из этой строки:

def * : MappedProjection[Nothing, (Option[Int], String)] = (id.?, name) <> (User.tupled, User.unapply)

В частности, User.tupled и User.unapply имеют следующие ошибки, соответственно:

Type mismatch, expected: Option[(Option[Int], String)] => NotInferedR, actual: Option[(Option[Int], String)] => User

и

Type mismatch, expected: NotInferedR => Option[(Option[Int], String)], actual: User => option[(Option[Int], String)]

Я не могу сказать, почему компилятор считает, что это должно быть NotInferedR; Я не могу найти какую-либо документацию по этому вопросу, и несколько учебников, которые, кажется, считают, что этого достаточно.

Это мой package.scala файл:

package nford

import slick.basic.DatabaseConfig
import slick.jdbc.JdbcProfile

package object domain {
  trait DatabaseBacking {
    val config: DatabaseConfig[JdbcProfile]
    val db: JdbcProfile#Backend#Database = config.db
  }
}

Это мой User.scala файл:

package nford.domain

import nford.domain
import slick.basic.DatabaseConfig
import slick.dbio.DBIOAction
import slick.jdbc.JdbcProfile
import slick.lifted.{Index, MappedProjection}

import scala.concurrent.Future

case class User(id: Option[Int], name: Option[String])

trait UserTable {
  this: DatabaseBacking =>

  import config.profile.api._

  private class User(tag: Tag) extends Table[User](tag, "user") {
    def id: Rep[Int] = column[Int]("id", O.PrimaryKey, O.AutoInc)
    def name: Rep[String] = column[String]("name")

    def * : MappedProjection[Nothing, (Option[Int], String)] = (id.?, name) <> (User.tupled, User.unapply)
  }

  val user = TableQuery[User]
}

Как мне устранить это несоответствие?

...