I'm a newbie to web development, and I did some examples like get data from MySQL database and show them in a jsp pages (use CRUDRepository), but in that way we can only show only one table data.
What should we do if we want to show data combined from two tables?
I found these while um searching,simply I m asking how we put a more complicated SQL query to this.
public interface UserRepository extends JpaRepository<User, Long> {
@Query("select u from User u where u.lastname like ?1%")
List<User> findByAndSort(String lastname, Sort sort);
@Query("select u.id, LENGTH(u.firstname) as fn_len from User u where u.lastname like ?1%")
List<Object[]> findByAsArrayAndSort(String lastname, Sort sort);
}
If we can use that complicated query (like three tables or more) here, should we create a new entity class according to query columns?
Then again, is that work because actually there isn't any table like that.
To get more complex data from DB you can use projections, for example:
public interface UserProjection {
Long getId();
Long getFirstNameLen();
}
@Query("select u.id as id, LENGTH(u.firstName) as firstNameLen from User u where u.lastname like ?1%")
List<UserProjection> getProjections(String lastName, Sort sort);
Note that you should use aliases in the query that must match with getters in the projection (... as firstNameLen
-> getFirstNameLen()
)
The same way you can get data from several (joined) entities.
If you have an entity with some associations, for example:
@Entity
public class User {
//...
@OneToMany
private List<Role> roles;
}
then you can use repository method to get the users and their roles data even without any projection, just for the main entity (User
). Then Spring does the rest of the work itself:
@EntityGraph(attributePaths = "roles")
List<User> findByFirstNameContainingIgnoreCase(String firstName);
or the same with query:
@Query("select distinct u from User u left join fetch u.roles where upper(p.firstName) like concat('%', upper(?1), '%')")
List<User> findWithQuery(String firstName);
In this case all users will have their lists of roles are filled with data from the roles
table.
(Note to use distinct
in the query to prevent the result from duplicated records, more info see here.)
Useful resources:
Spring Data JPA - Reference Documentation