6

我正在尝试存储一个整数列表,这就是我正在做的事情:

模型

case class Score(
  scoresPerTime: List[Int]
)

object Scores extends Table[Score]("SCORES"){
   def scorePerTime = column[List[Int]]("SCORE_PER_TIME")
   //...more code
}

控制器

val form = Form(
  Map(
    "scoresPerTime" -> list(number)
  )(Score.apply)(Score.unapply)
)

我得到一个编译错误

.... could not find implicit value for parameter tm: scala.slick.lifted.TypeMapper[List[Int]][error]   def scorePerTime = column[List[Int]]("SCORE_PER_TIME")

如何解决此问题以输入列表?或者尝试其他选项,例如元组、枚举...

4

1 回答 1

6

您可以通过定义从 List[Int] 到 String 的类型映射器来做到这一点,反之亦然。

一种可能:

implicit def date2dateTime = MappedTypeMapper.base[List[Int], String](
  list => list mkString ",",
  str => (str split "," map Integer.parseInt).toList
)

我说这是可能的,因为我没有测试过。不确定它返回列表的事实是否会破坏 Slick。一个可能模棱两可的地方是聚合查询,您想要计算数量,而不是做 a count(field)(这显然是一个)。

但这完全没有关系。关系方式是创建一个包含两个字段的新表,一个外键引用 table 中的一行,SCORES另一个字段引用一个SCORE_PER_TIME. 外键应该是非唯一索引,因此搜索速度很快。并且 slick 很好地处理了这个问题。

于 2013-07-12T21:35:37.080 回答