我有(工作)以下代码:
val actions = (for {
_ <- slickUsers.insertOrUpdate(dbUser)
loginInfo <- loginInfoAction
_ <- slickUserLoginInfos += DBUserLoginInfo(dbUser.userID, loginInfo.id.get)
} yield ()).transactionally
loginInfoAction是一个DBIOAction。我想将loginInfoActions更改为DBIOAction的Seq,然后对它们中的每一个执行相同的DBUserLoginInfo操作。
我愚蠢地尝试了这个:
val actions = (for {
_ <- slickUsers.insertOrUpdate(dbUser)
loginInfoAction <- loginInfoActions
loginInfo <- loginInfoAction
_ <- slickUserLoginInfos += DBUserLoginInfo(dbUser.userID, loginInfo.id.get)
} yield ()).transactionally
但是它没有按预期的方式工作(尽管loginInfoAction会在DBIOAction的Seq上进行迭代)。我是Slick的新手,所以如果我错过了任何内容,请不要犹豫将我指向文档!
最佳答案
DBIO.sequence
使用DBIO.sequence
将List[DBIO[_]]
转换为DBIO[List[_]]
并使用理解。DBIO.sequence
将DBIO的序列转换为DBIO[Seq[_]]
。
例如,假设我们有一个函数getUser
def getUser(userId: Long): DBIO[User]
def getAllUsers(userIds: List[Long]): DB[List[User]] = {
DBIO.sequence(userIds.map(getUser))
}
DBIO.Sequence
将List[DBIO[_]]
转换为DBIO[List[_]]
现在您的代码成为
val actions = (for {
_ <- slickUsers.insertOrUpdate(dbUser)
loginInfoActionList <- DBIO.sequence(loginInfoActions)
_ <- DBIO.sequence { loginInfoActionList.map { loginInfo =>
slickUserLoginInfos += DBUserLoginInfo(dbUser.userID, loginInfo.id.get) }
}
} yield ()).transactionally