如何在Slick 3.1.x中运行transactionally
语句,并将结果捕获到Future中(不使用等待)?在事务中运行并检索未来的结果
此作品(但使用等待)
val action = db.run((for {
_ <- table1.filter(_.id1 === id).delete
_ <- table2.filter(_.id2=== id).delete
} yield()).transactionally)
val result = Await.result(action, Duration.Inf)
然而,这并不显示任何信息:
val future = db.run((for {
_ <- table1.filter(_.id1 === id).delete
_ <- table2.filter(_.id2=== id).delete
} yield()).transactionally)
future.map { result => println("result:"+result) }
UPDATE
这是从没有按程序采取的实际代码没有工作。它打印“1”,但它从不打印“2”
case class UserRole (sk: Int, name: String)
class UserRoleDB(tag: Tag) extends Table[UserRole](tag, "user_roles") {
def sk = column[Int]("sk", O.PrimaryKey)
def name = column[String]("name")
def * = (sk, name) <> ((UserRole.apply _).tupled, UserRole.unapply)
}
class Test extends Controller {
def index = Action.async { request =>
val db = Database.forConfig("db1")
val userRoles = TableQuery[UserRoleDB]
val ur = UserRole(1002,"aaa")
try {
val action = (for {
userRole2 <- userRoles += ur
} yield (userRole2)).transactionally
val future = db.run(action)
println(1)
// val result = Await.result(future, Duration.Inf)
future.map { result => {
println(2)
Ok("Finished OK")
}
}
}
finally db.close
}
}
你的代码没问题。也许应用程序在未来完成之前退出。在映射未来之后尝试添加一些'Thread.sleep'来看看它是否有效。 –
对于像'println'这样的副作用函数(返回'Unit''),最好使用'foreach'(而不是'map')。 –
如果'future.map'没有启动它,因为未来可能是失败的,请尝试附加'.recover'或'.recoverWith'。 –