假设我为Vapor配置了数据库。我有两个具有父子关系的表。作为示例,让我们使用Team作为父表,将Player作为子表。
使用Fluent可以很容易地与团队中的所有球员一起返回json。与玩家团队一起返回json也很容易。但是,这是返回带有团队属性和玩家数组的json的最简单方法吗?
相反。给定具有团队属性和一组玩家的json,这是从该json创建团队和玩家的最简单方法吗?
Fluent可以帮助您吗?还是我们应该自己进行管理?
非常感谢您!
卡洛斯
答案 0 :(得分:3)
通常,您创建一个符合Content
的特殊结构以获取JSON数据并返回JSON数据。对于您的示例,它看起来像这样:
struct TeamPlayerContent: Content {
let team: Team
let players: [Player]
}
然后,当您收到请求时,您可以对正文进行解码并获得一个struct实例:
router.post(TeamPlayerContent.self, at: "teams") { request, body in
// Save the team and player models
}
然后,当您从数据库中获取Team
和Player
数据时,您可以创建一个结构实例,并从路由中将其返回:
router.get("teams", Team.parameter) ( request in
return try request.paramaters.next(Team.self).flatMap { team in
let players = try Player.query(on: request).filter(\.teamID == team.requireID()).all()
return players.and(team)
}.map { data in
return TeamPlayerContent(team: data.1, players: data.0)
}
}