gpt4 book ai didi

scala - 光滑/Scala : What is a Rep[Bind] and how do I turn it into a value?

转载 作者:行者123 更新时间:2023-12-04 03:57:43 25 4
gpt4 key购买 nike

我试图弄清楚 Slick(Scala 函数关系模型)。我已经开始在 Slick 3.0.0 中构建原型(prototype),但是当然……大多数文档要么已过时,要么不完整。

我已经成功地达到了可以创建模式并从数据库返回对象的地步。

问题是,我得到的是一个“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[] 是 slick 中使用的 Column[] 数据类型的替代品。

users.map(_.id) 返回所有行的列值( 'n_user_id' )

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

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

获得的值为 类型专栏[长] [ 现在是 代表[长] ]。
您不能直接打印上述 的值结果集 因为它不是任何 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])

    两者意思相同,所以可以直接使用前者,去掉后者

    关于scala - 光滑/Scala : What is a Rep[Bind] and how do I turn it into a value?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30132680/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com