使用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对象。
改用Users.autoInc.insert。
也可以看看: https://github.com/slick/slick/issues/10 https://github.com/slick/slick/commit/09a65a8e88a0363412e218dc5c06023b69809649 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |