Slick/Scala: 什么是 Rep[Bind] 以及如何将其转换为值?
Slick/Scala: What is a Rep[Bind] and how do I turn it into a value?
我正在尝试了解 Slick(Scala 功能关系模型)。我已经开始在 Slick 3.0.0 中构建原型,但是当然......大部分文档要么过时要么不完整。
我已经设法达到可以创建模式和 return 来自数据库的对象的地步。
问题是,我要取回的是 "Rep[Bind]" 而不是我希望取回的对象。我不知道该怎么做这个值。例如,如果我尝试像 rep.countDistinct.result 这样的操作,我会崩溃。
这是代码的简要概要...为简洁起见删除了一些代码:
class UserModel(tag: Tag) extends Table[User](tag, "app_dat_user_t") {
def id = column[Long]("n_user_id", O.PrimaryKey)
def created = column[Long]("d_timestamp_created")
def * = (id.?, created) <> (User.tupled, User.unapply)
}
case class User(id: Option[Long], created: Long)
val users = TableQuery[UserModel]
(users.schema).create
db.run(users += User(Option(1), 2))
println("ID is ... " + users.map(_.id)) // prints "Rep[Bind]"... huh?
val users = for (user <- users) yield user
println(users.map(_.id).toString) // Also prints "Rep[Bind]"...
我找不到 "unwrap" Rep 对象的方法,也找不到任何关于它是什么或如何使用它的明确解释。
Rep[] 是 slick 中使用的 Column[] 数据类型的替代。
users.map(_.id) returns 列的值('n_user_id') 所有行
val result : Rep[Long] = users.map(_.id)
users.map(_.id) // => select n_user_id from app_dat_user_t;
获得的值是 Column[Long] 类型 [现在是 Rep[Long] ]。
您不能直接打印上述 resultSet 的值,因为它不是任何 Scala 集合类型
您可以先将其转换为一些 scala 集合,然后将其打印为
下面:
var idList : List[Long] = List()
users.map(_.id).forEach(id =>
idList = idList :+ id
)
println(idList)** // 如果你需要一次打印所有的ids
否则你可以简单地使用:
users.map(_.id).forEach(id =>
println(id)
) // print for each id
并且,
val users = TableQuery[UserModel] // => returns Query[UserModel, UserModel#TableElementType, Seq])
val users = for (user <- users) yield user // => returns Query[UserModel, UserModel#TableElementType, Seq])
两者意思一样,所以可以直接用前者去掉后者
我正在尝试了解 Slick(Scala 功能关系模型)。我已经开始在 Slick 3.0.0 中构建原型,但是当然......大部分文档要么过时要么不完整。
我已经设法达到可以创建模式和 return 来自数据库的对象的地步。
问题是,我要取回的是 "Rep[Bind]" 而不是我希望取回的对象。我不知道该怎么做这个值。例如,如果我尝试像 rep.countDistinct.result 这样的操作,我会崩溃。
这是代码的简要概要...为简洁起见删除了一些代码:
class UserModel(tag: Tag) extends Table[User](tag, "app_dat_user_t") {
def id = column[Long]("n_user_id", O.PrimaryKey)
def created = column[Long]("d_timestamp_created")
def * = (id.?, created) <> (User.tupled, User.unapply)
}
case class User(id: Option[Long], created: Long)
val users = TableQuery[UserModel]
(users.schema).create
db.run(users += User(Option(1), 2))
println("ID is ... " + users.map(_.id)) // prints "Rep[Bind]"... huh?
val users = for (user <- users) yield user
println(users.map(_.id).toString) // Also prints "Rep[Bind]"...
我找不到 "unwrap" Rep 对象的方法,也找不到任何关于它是什么或如何使用它的明确解释。
Rep[] 是 slick 中使用的 Column[] 数据类型的替代。
users.map(_.id) returns 列的值('n_user_id') 所有行
val result : Rep[Long] = users.map(_.id)
users.map(_.id) // => select n_user_id from app_dat_user_t;
获得的值是 Column[Long] 类型 [现在是 Rep[Long] ]。 您不能直接打印上述 resultSet 的值,因为它不是任何 Scala 集合类型
您可以先将其转换为一些 scala 集合,然后将其打印为 下面:
var idList : List[Long] = List() users.map(_.id).forEach(id => idList = idList :+ id )
println(idList)** // 如果你需要一次打印所有的ids
否则你可以简单地使用:
users.map(_.id).forEach(id => println(id) ) // print for each id
并且,
val users = TableQuery[UserModel] // => returns Query[UserModel, UserModel#TableElementType, Seq])
val users = for (user <- users) yield user // => returns Query[UserModel, UserModel#TableElementType, Seq])
两者意思一样,所以可以直接用前者去掉后者