我试图弄清楚Slick(Scala功能关系模型)。我已经开始在Slick 3.0.0中构建原型,但当然......大多数文档都已过时或不完整。
我已经设法达到了可以创建模式并从数据库返回对象的程度。
问题是,我要回的是“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]"...
我找不到一种“解包”Rep对象的方法,但我找不到任何明确的解释它是什么或如何使用它。
Rep []是光滑中使用的Column []数据类型的替代品。
users.map(_。id)返回所有行的Column('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集合类型
var idList : List[Long] = List()
users.map(_.id).forEach(id =>
idList = idList :+ id
)
println(idList)** //如果您需要一次打印所有IDusers.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])
两者的意思相同,所以你可以直接使用前者并删除后者