我有(工作)以下代码:

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.sequenceList[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.SequenceList[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

09-26 01:48