I have query which returns data from multiple entities
@Override
public List<PlayerDetails> testPlayerQuerry() {
return copyTest(em.createNativeQuery("select player_name, pg.player_game_score, g.game_description from player p\n"
+ "join Player_Game pg on p.player_id = pg.fk_player_id\n"
+ "join Game g on pg.fk_game_id = g.game_id\n"
+ "where g.game_id = 2").getResultList());
Retrieving data from query which returns data form one entity is relatively straight forward it can be done like this
private List<PlayerDetails> copyPlayersToDetails(List< Player> players) {
List<PlayerDetails> list = new ArrayList<PlayerDetails>();
Iterator i = players.iterator();
while (i.hasNext()) {
Player player = (Player) i.next();
PlayerDetails details = new PlayerDetails(player.getPlayerId(),
player.getPlayerName(), player.getPlayerRating());
list.add(details);
}
return list;
}
The question is how to do it when query stores data from more than one entity?