如何在 slick 3 的 DBIOAction 组合中使用 Future?
How to use Future inside DBIOAction composition in slick 3?
Slick 3 通过使用flatMap 方法提供DBIOAction 组合。此外,我们可以在两个 DBIOAction 之间在后端进行一些计算。这在大多数情况下都很好,但是当计算结果在像 Future 这样的 monad 中时我应该怎么做?有阻塞方式的代码:
val fooQuery = TableQuery[FooTable]
val barQuery = TableQuery[BarTable]
def requestService(content: Iterable[String]): Future[Iterable[Long]] = ???
def modify(ids: Iterable[Long], change: String) = {
val query = fooQuery.filter(_.id inSet ids).result.flatMap{ fooSeq =>
val content = fooSeq.map(_.contentField)
val requestServiceFuture = requestService(content)
val serviceResult = Await.result(requestServiceFuture, 1.minute)
barQuery.filter(_.id inSet serviceResult).delete //or other action
}
db.run(query.transactionally)
}
有没有无需等待的异步执行此代码的方法?
您可以使用 DBIOAction.from
从 Future
创建 DBIO
,然后使用 flatMap
与其他 DBIO 组合
val query = for {
fooSeq <- fooQuery.filter(_.id inSet ids).result
content = fooSeq.map(_.contentField)
serviceResult <- DBIOAction.from(requestService(content))
result <- barQuery.filter(_.id inSet serviceResult).delete
} yield result
db.run(query.transactionally)
http://slick.lightbend.com/doc/3.1.1/api/index.html#slick.dbio.DBIOAction$
Slick 3 通过使用flatMap 方法提供DBIOAction 组合。此外,我们可以在两个 DBIOAction 之间在后端进行一些计算。这在大多数情况下都很好,但是当计算结果在像 Future 这样的 monad 中时我应该怎么做?有阻塞方式的代码:
val fooQuery = TableQuery[FooTable]
val barQuery = TableQuery[BarTable]
def requestService(content: Iterable[String]): Future[Iterable[Long]] = ???
def modify(ids: Iterable[Long], change: String) = {
val query = fooQuery.filter(_.id inSet ids).result.flatMap{ fooSeq =>
val content = fooSeq.map(_.contentField)
val requestServiceFuture = requestService(content)
val serviceResult = Await.result(requestServiceFuture, 1.minute)
barQuery.filter(_.id inSet serviceResult).delete //or other action
}
db.run(query.transactionally)
}
有没有无需等待的异步执行此代码的方法?
您可以使用 DBIOAction.from
从 Future
创建 DBIO
,然后使用 flatMap
val query = for {
fooSeq <- fooQuery.filter(_.id inSet ids).result
content = fooSeq.map(_.contentField)
serviceResult <- DBIOAction.from(requestService(content))
result <- barQuery.filter(_.id inSet serviceResult).delete
} yield result
db.run(query.transactionally)
http://slick.lightbend.com/doc/3.1.1/api/index.html#slick.dbio.DBIOAction$