7

私は Scala を初めて使用し、私が達成しようとしていることでさえ Java では単純すぎるため、Scala と混同されているように感じます。

私が望むのは、 a を取得し、UserPermissionのクエリを使用して彼Roleと彼の個人に基づいて入力することPermissionsです。

知るまで、私は次のコードを持っています:

/**
* Finds a user by its loginInfo.
*
* @param loginInfo The loginInfo of the user to find.
* @return The found user or None if no user for the given login info could be found.
*/
def find(loginInfo: LoginInfo): Future[Option[models.admin.User]] = {

val userQuery = for {
  dbLoginInfo <- loginInfoQuery(loginInfo)
  dbUserLoginInfo <- Userlogininfo.filter(_.logininfoid === dbLoginInfo.id)
  dbUser <- User.filter(_.userid === dbUserLoginInfo.userid)
  user <- dbUser match {
    case u =>
      val permissionQuery = for {
        dbUserPermission <- Userpermission.filter(_.userid === u.userid)
        dbPermission <- Permission.filter(_.id === dbUserPermission.permissionid)
      } yield dbPermission

      val rolePermissionQuery = for {
        dbUserRole <- Userrole.filter(_.userid === u.userid)
        dbRole <- Role.filter(_.id === dbUserRole.roleid)
        dbRolePermission <- Rolepermission.filter(_.roleid === dbRole.id)
        dbPermission <- Permission.filter(_.id === dbRolePermission.permissionid)
      } yield dbPermission

      val unionPermissionQuery = permissionQuery union rolePermissionQuery

      db.run(unionPermissionQuery.result).map(_.map(_.name).toList).map { permission =>

        models.admin.User(
          UUID.fromString(u.userid.toString),
          u.firstname.toString,
          u.lastname.toString,
          u.jobtitle.toString,
          loginInfo,
          u.email.toString,
          false,
          Some(permission),
          false)
      }
    case None => None
  }
} yield user

db.run(userQuery.result.headOption)

}

次のエラーが発生しました。

pattern type is incompatible with expected type;
[error]  found   : None.type
[error]  required: UserDAOImpl.this.User
[error]         case None => None
[error]              ^
[error] play/modules/admin/app/models/daos/impl/UserDAOImpl.scala:36: value map is not a member of Object
[error]       user <- dbUser match {
[error]                      ^
[error] play/modules/admin/app/models/daos/impl/UserDAOImpl.scala:34: type mismatch;
[error]  found   : UserDAOImpl.this.Userlogininfo => slick.lifted.Query[Nothing,Nothing,Seq]
[error]  required: UserDAOImpl.this.Userlogininfo => slick.lifted.Query[Nothing,T,Seq]
[error]       dbUserLoginInfo <- Userlogininfo.filter(_.logininfoid === dbLoginInfo.id)
[error]                       ^
[error] play/modules/admin/app/models/daos/impl/UserDAOImpl.scala:33: type mismatch;
[error]  found   : UserDAOImpl.this.Logininfo => slick.lifted.Query[Nothing,Nothing,Seq]
[error]  required: UserDAOImpl.this.Logininfo => slick.lifted.Query[Nothing,T,Seq]
[error]       dbLoginInfo <- loginInfoQuery(loginInfo)
[error]                   ^
[error] play/modules/admin/app/models/daos/impl/UserDAOImpl.scala:69: value headOption is not a member of UserDAOImpl.this.driver.DriverAction[Seq[Nothing],UserDAOImpl.this.driver.api.NoStream,slick.dbio.Effect.Read]
[error]     db.run(userQuery.result.headOption)
[error]                             ^
[error] 5 errors found
4

1 に答える 1

0

を使用して for-comprehension を使用するyield場合は常に、ある種の「ラップされた」値 (モナド) を使用していることを理解する必要があります。a Future、 a List、 an Option、またはその他のモナドであれば何でもかまいません。

したがって、パターンは次のようなものです。

for {
  someValue <- someWrappedValue()
  someOtherValue <- someWrappedOtherValue(someValue)
} yield someOtherValue

を使用している場合はFuture、次のルールを使用できます。

  • a の右側にあるものはすべて a で<-なければなりませんFuture
  • a の左側はすべて<-「ラップされていない」値です
  • for-comprehension 全体の値はyieldFuture

List、などのルールは同じですが、Option同じ for 内包表記内で混在させることはできません。

matchエラーの 1 つは、ステートメントの結果が type であることを示唆していますObject。これは、scala が一致するすべてのケースに共通の型を見つけられなかったことを意味します。すべてのケースで を生成する必要がありますFuture(これは、この for-comprehension で作業しているためです)。

私の推測では、次のものを置き換える必要があります。

case None => None

と:

case None => Future.successful(None)

しかし、それ以上の情報がないと確実に知ることは困難です。

Javaの方が単純であることについて:正確ではありません。もう少し複雑なのは言語ではなく、多くのメソッドが非同期であるという事実です。これを scala で同期的に実行する場合は、Java と同じかそれ以上に単純になります。ただし、結果を待つたびにスレッドをブロックすることになります。これは Java の場合です (同期呼び出しを想定)。

于 2015-12-11T22:34:42.973 に答える