繁体   English   中英

无法找到类型证据参数的隐式值

[英]Could not find implicit value for evidence parameter of type

我正在尝试编写一个映射器,将 Option[sql.Date] 转换为 Option[sql.Timestamp]。 为此,我使用以下代码:

package model.db

import java.sql.Date

import com.typesafe.slick.driver.ms.SQLServerDriver.simple._

abstract class RichTable[T](tag: Tag, name: String, schema: Option[String] = Some("dbo")) extends Table[T](tag, schema, name) {
  def id: Column[Option[Long]] = column[Option[Long]]("id", O.PrimaryKey, O.AutoInc)
  def cancelled: Column[Option[Date]] = column[Option[Date]]("cancelled")(DateMapper.sqlDate2SqlTimestampOptionMapper)
}

abstract class LoggableTable[T](tag: Tag, name: String, schema: Option[String] = Some("dbo")) extends RichTable[T](tag, name, schema) {
  def createdAt: Column[Date] = column[Date]("created_at", O.NotNull)(DateMapper.sqlDate2SqlTimestampMapper)
}

object DateMapper {
  val sqlDate2SqlTimestampMapper = MappedColumnType.base[java.sql.Date, java.sql.Timestamp](
    { sqlDate => new java.sql.Timestamp(sqlDate.getTime) },
    { sqlTimestamp => new java.sql.Date(sqlTimestamp.getTime) })

  val sqlDate2SqlTimestampOptionMapper = MappedColumnType.base[scala.Option[java.sql.Date], scala.Option[java.sql.Timestamp]](
    { sqlDate => scala.Some(new java.sql.Timestamp(sqlDate.get.getTime)) },
    { sqlTimestamp => scala.Some(new java.sql.Date(sqlTimestamp.get.getTime)) })
} 

sqlDate2SqlTimestampMapper工作正常,所以我用它作为sqlDate2SqlTimestampOptionMapper的基本代码。

当我尝试编译时,出现以下错误:

错误:(21, 126) 找不到 com.typesafe.slick.driver.ms.SQLServerDriver.BaseColumnType[Option[java.sql.Timestamp]] val sqlDate2SqlTimestampOptionMapper = MappedColumnType.base[scala.Option 类型的证据参数的隐式值[java.sql.Date], scala.Option[java.sql.Timestamp]](

错误:(21, 126) 方法库的参数不足: (隐式证据$5: scala.reflect.ClassTag[Option[java.sql.Date]], 隐式证据$6: com.typesafe.slick.driver.ms.SQLServerDriver .BaseColumnType[Option[java.sql.Timestamp]])com.typesafe.slick.driver.ms.SQLServerDriver.BaseColumnType[Option[java.sql.Date]]。 未指定值参数证据$6。 val sqlDate2SqlTimestampOptionMapper = MappedColumnType.base[scala.Option[java.sql.Date], scala.Option[java.sql.Timestamp]](

我怎样才能解决这个问题?

先感谢您。

您不需要选项映射器。 删除这段代码。

val sqlDate2SqlTimestampOptionMapper = MappedColumnType.base[scala.Option[java.sql.Date], scala.Option[java.sql.Timestamp]](
    { sqlDate => scala.Some(new java.sql.Timestamp(sqlDate.get.getTime)) },
    { sqlTimestamp => scala.Some(new java.sql.Date(sqlTimestamp.get.getTime)) })

现在你的日期映射器变成

object DateMapper {
  val sqlDate2SqlTimestampMapper = MappedColumnType.base[java.sql.Date, java.sql.Timestamp](
    { sqlDate => new java.sql.Timestamp(sqlDate.getTime) },
    { sqlTimestamp => new java.sql.Date(sqlTimestamp.getTime) })
}

在 Slick 中,如果您为某个T提供映射,则无需为Option[T]实现映射

正如@pamu 所说,Option 不需要映射器。 堆栈跟踪抱怨隐含值; 所以我所做的是让映射器隐含,问题就解决了。

package model.db

import java.sql.Date

import com.typesafe.slick.driver.ms.SQLServerDriver.simple._

abstract class RichTable[T](tag: Tag, name: String, schema: Option[String] = Some("dbo")) extends Table[T](tag, schema, name) {
  def id: Column[Option[Long]] = column[Option[Long]]("id", O.PrimaryKey, O.AutoInc)
  def cancelled: Column[Option[Date]] = column[Option[Date]]("cancelled")
}

abstract class LoggableTable[T](tag: Tag, name: String, schema: Option[String] = Some("dbo")) extends RichTable[T](tag, name, schema) {
  def createdAt: Column[Date] = column[Date]("created_at", O.NotNull)
}

object DateMapper {
  implicit val sqlDate2SqlTimestampMapper = MappedColumnType.base[java.sql.Date, java.sql.Timestamp](
    { sqlDate => new java.sql.Timestamp(sqlDate.getTime) },
    { sqlTimestamp => new java.sql.Date(sqlTimestamp.getTime) })
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM