加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

使用Scala中的Slick库获取自动增量值

发布时间:2020-12-16 09:32:31 所属栏目:安全 来源:网络整理
导读:如何获取Slick插入的记录的自动递增值?以下代码打印1111.我打算打印1234 import scala.slick.driver.H2Driver.simple._object TestMappedTable extends App{ case class User(id: Option[Int],first: String,last: String) object Users extends Table[User
如何获取Slick插入的记录的自动递增值?以下代码打印1111.我打算打印1234

import scala.slick.driver.H2Driver.simple._

object TestMappedTable extends App{
    case class User(id: Option[Int],first: String,last: String)

    object Users extends Table[User]("users") {
        def id = column[Int]("id",O.PrimaryKey,O.AutoInc)
        def first = column[String]("first")
        def last = column[String]("last")
        def * = id.? ~ first ~ last <> (User,User.unapply _)
    }

  implicit val session = Database.forURL("jdbc:h2:mem:test1",driver = "org.h2.Driver").createSession()
  session.withTransaction{
    Users.ddl.create

    print(Users.insert(User(None,"Jack","Green" )))
    print(Users.insert(User(None,"Joe","Blue" )))
    print(Users.insert(User(None,"John","Purple" )))
    print(Users.insert(User(None,"Jim","Yellow" )))
  }
}

我正在使用Slick 0.11.2作为Scala 2.10.0-RC1

解决方法

您可以这样检索生成的值。

将autoInc方法添加到Users对象。

def autoInc = id.? ~ first ~ last <> (User,User.unapply _) returning id

改用Users.autoInc.insert。

print(Users.autoInc.insert(User(None,“Jack”,“Green” )))

也可以看看:

https://github.com/slick/slick/issues/10

https://github.com/slick/slick/commit/09a65a8e88a0363412e218dc5c06023b69809649

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读