Я использую play-slick для своей scala Play! API фиктивного отдыха.Scala Play Будущая взаимозависимость
Итак, мне нужно получить записи из нескольких таблиц. Но, они взаимозависимы, то есть
Table_1 Table_2
id1 id2
id2
Чтобы извлечь запись из Table_2 я должен принести запись из Table_1, а затем с помощью id2 выборки из Table_2.
Мой контроллер:
def getEntity(id : Long) = Action.async {
table1DAO.findById(id) map { t1 =>
t1 map { t1Entity =>
table2DAO.findById(t1Entity.id2) map { t2 =>
t2 map { t2Entity =>
Ok(Json.toJson(CombiningClass(t1Entity, t2Entity)))
} getOrElse { Ok(Json.toJson(t1Entity)) }
}
} getOrElse { NoContent }
}
}
После компиляции, я получаю:
[error] DummyController.scala:17: overloaded method value async with alternatives:
[error] [A](bodyParser: play.api.mvc.BodyParser[A])(block: play.api.mvc.Request[A] => scala.concurrent.Future[play.api.mvc.Result])play.api.mvc.Action[A] <and>
[error] (block: play.api.mvc.Request[play.api.mvc.AnyContent] => scala.concurrent.Future[play.api.mvc.Result])play.api.mvc.Action[play.api.mvc.AnyContent] <and>
[error] (block: => scala.concurrent.Future[play.api.mvc.Result])play.api.mvc.Action[play.api.mvc.AnyContent]
[error] cannot be applied to (scala.concurrent.Future[Object])
[error] def getEntity(id : Long) = Action.async {
[error] ^
[error] one error found
Вот мой метод DAO:
def findById(id : Long): Future[Option[A]] = {
db.run(tableQ.filter(_.id === id).result.headOption)
}
PS: Я очень новой для функциональной парадигмы и scala, так что если вы можете, простите мое невежество.
Попробуйте аннотировать верхний 'map':' table1DAO.findById (id) .map [Result] {t1 => ...} ', чтобы убедиться, что вы даете' Future [Result] '. Постскриптум Читаемость вашего кода принесет пользу из-за понимания. – cchantep