Skip to content

Commit 2697671

Browse files
committed
Part 12: Add FifthUserRepository.java
1 parent 6b84e30 commit 2697671

File tree

1 file changed

+41
-0
lines changed

1 file changed

+41
-0
lines changed
Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
package spring.oldboy.database.repository.user_repository;
2+
3+
/* Part 10: Lesson 54 - Использование @EntityGraph */
4+
5+
import org.springframework.data.domain.Page;
6+
import org.springframework.data.domain.Pageable;
7+
import org.springframework.data.jpa.repository.EntityGraph;
8+
import org.springframework.data.jpa.repository.JpaRepository;
9+
import org.springframework.data.jpa.repository.Query;
10+
import org.springframework.stereotype.Repository;
11+
import spring.oldboy.database.entity.User;
12+
13+
/* Изменим наш класс на интерфейс и расширим JpaRepository */
14+
@Repository
15+
public interface FifthUserRepository extends JpaRepository<User, Long> {
16+
17+
/*
18+
Part 10: Lesson 54:
19+
20+
Применим @EntityGraph его параметр value, который работает с именованными
21+
графами, см. сущность User. Стоит обратить внимание, что Company у нас -
22+
LAZY сущность и для ее получения, Hibernate сформирует дополнительный запрос.
23+
*/
24+
@EntityGraph("User.company")
25+
@Query(value = "select u from User u",
26+
countQuery = "select count(distinct u.firstname) from User u")
27+
Page<User> findAllUserWithNamedEntityGraphBy(Pageable pageable);
28+
29+
/*
30+
В данном случае мы уже используем атрибуты аннотации, чтобы подтянуть LAZY сущности,
31+
а в случае с company.locales мы подтягиваем 'подграф', поскольку локали для сущности
32+
Company тоже LAZY. Но при этом мы не увеличиваем количество строк кода в User, для
33+
настройки подграфа и даже не создаем именованный сущностной граф - @NamedEntityGraph
34+
в сущности UserS.
35+
*/
36+
@EntityGraph(attributePaths = {"company", "company.locales"})
37+
@Query(value = "select u from User u",
38+
countQuery = "select count(distinct u.firstname) from User u")
39+
Page<User> findAllUserWithAttributeEntityGraphBy(Pageable pageable);
40+
41+
}

0 commit comments

Comments
 (0)