如何将Future [Vector [UserLocation]]转换为Future [Vector [User]]

Bla*_*man 1 scala future

我有一个方法,我想返回Future[Vector[user]].

该方法userLocationService.getUserLocationsInList将返回一个Future[Vector[UserLocation]].

UserLocation看起来像这样:

case class UserLocation(id: Int, locationId: Int, userId: Int)


def getUsersInLocation(locationIdList: Set[Int]): Future[Vector[User]] = {

   userLocationService.getUserLocationsInList(locationIdList).map{
      userLocations =>
          // ????????????
   }

}
Run Code Online (Sandbox Code Playgroud)

我有一个方法,返回基于UserId的单个用户,如:

userService.getById(userId: Int): Future[User]
Run Code Online (Sandbox Code Playgroud)

如何根据上述内容构建Future [Vector [User]]?

Mic*_*jac 7

如果你mapFuture[Vector[UserLocation]],你可以很容易地生成Vector[Future[User]]内,从包含的Vector[UserLocation]:

userLocations.map(location => userService.getById(location.userId))
Run Code Online (Sandbox Code Playgroud)

您可以使用Future.sequence将其反转Vector[Future[User]]Future[Vector[User]]:

Future.sequence(userLocations.map(location => userService.getById(location.userId)))
Run Code Online (Sandbox Code Playgroud)

或使用Future.traverse:

Future.traverse(userLocations) { location => userService.getById(location.userId) }
Run Code Online (Sandbox Code Playgroud)

这将留下一个Future[Future[Vector[User]]],可以通过更改map为a 来修复flatMap.把它们放在一起:

def getUsersInLocation(locationIdList: Set[Int]): Future[Vector[User]] = {
  userLocationService.getUserLocationsInList(locationIdList).flatMap { locations =>
    Future.traverse(locations) { location =>
      userService.getById(location.userId)
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

或者有一个理解:

def getUsersInLocation(locationIdList: Set[Int]): Future[Vector[User]] = {
  for {
    locations <- userLocationService.getUserLocationsInList(locationIdList)
    users <- Future.traverse(locations) { location =>
      userService.getById(location.userId)
    }
  } yield users
}
Run Code Online (Sandbox Code Playgroud)