Slick / Scala:什么是Rep [Bind],如何将其变成值?

时间:2015-05-08 20:52:51

标签: scala slick

我试图找出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]"...

我无法找到解开&#34;解开&#34; Rep对象,我找不到任何明确的解释,它是什么或如何使用它。

1 个答案:

答案 0 :(得分:8)

Rep []取代了光滑中使用的Column []数据类型。

users.map(_。id)会返回所有行的列值(&#39; n_user_id&#39;

val result : Rep[Long] = users.map(_.id)

users.map(_.id) // => select n_user_id from app_dat_user_t;

获得的值类型为列[长] [现在 Rep [Long] ]。 您无法直接打印上述 resultSet 的值,因为它不属于任何scala集合类型

  • 您可以先将其转换为某些scala集合,然后将其打印为 下面:

    var idList : List[Long] = List()
    users.map(_.id).forEach(id =>
    idList = idList :+ id
    )
    

    println(idList)** //如果您需要一次打印所有ID

  • 否则您只需使用:

    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])

两者意思相同,所以你可以直接使用前者并删除后者