|
| 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