0

使用 Slick 加入时的问题:我有 2 个表 User 和 UserInfo,我想离开它们以获取用户信息。我试过这个:

val q = for{
  (user,info) <- User leftJoin UserInfo on (_.id === _.userid)
} yield(user, info)

但是 UserInfo 表有一些可以为空的字段,所以当我尝试执行查询时:

q.map(user_info => (user_info._1,user_info._2)).list

它会出错,因为 user_info._2 有一些空值。我知道在 UserInfo 中产生每个字段并为可空字段添加 getOrElse(None) 的解决方案。但是,UserInfo 有很多字段,所以我不想使用它。

谁能帮我?

4

1 回答 1

2

您可以做的是,定义一个进行转换的函数,然后在您的地图中使用它:

def nullToOption[A](input: A): Option[A] = input match {
  case null => None
  case x    => Some(x)
}

然后你只需在你的地图中使用它。

我用一个简单的列表做了一个简单的例子:

val lst = List("Hello", null, "hi", null)

val newlst = map lst nullToOption

newList现在是以下内容:List(Some("Hello"), None, Some("hi"), None)

当然,您可以修改 nullToOption 以满足您的需求;这是一个采用元组的版本:

def nullToOption[A, B](input: (A,B)): (Option[A], Option[B]) = input match {
  case (x, y)       => (Some(x), Some(y))
  case (x, null)    => (Some(x), None)
  case (null, y)    => (None, Some(y))
  case (null, null) => (None, None)
}
于 2014-07-03T07:39:51.310 回答