|
4 | 4 | import kattsyn.dev.rentplace.entities.Property; |
5 | 5 | import org.springframework.data.jpa.repository.JpaRepository; |
6 | 6 | import org.springframework.data.jpa.repository.Query; |
| 7 | +import org.springframework.data.repository.query.Param; |
7 | 8 |
|
8 | 9 | import java.util.List; |
| 10 | +import java.util.Optional; |
9 | 11 |
|
10 | 12 | public interface PropertyRepository extends JpaRepository<Property, Long> { |
11 | 13 |
|
12 | 14 | @Query(""" |
13 | 15 | SELECT DISTINCT p |
14 | 16 | FROM Property p |
15 | | - LEFT JOIN FETCH p.categories |
16 | | - LEFT JOIN FETCH p.facilities |
| 17 | + LEFT JOIN FETCH p.owner o |
| 18 | + LEFT JOIN FETCH p.categories c |
| 19 | + LEFT JOIN FETCH p.facilities f |
17 | 20 | LEFT JOIN FETCH p.images |
| 21 | + LEFT JOIN FETCH o.image |
| 22 | + LEFT JOIN FETCH c.image |
| 23 | + LEFT JOIN FETCH f.image |
18 | 24 | """) |
19 | 25 | List<Property> findAllWithRelations(); |
20 | 26 |
|
21 | | - List<Property> findAllByOwnerEmail(String email); |
| 27 | + @Query(""" |
| 28 | + SELECT DISTINCT p |
| 29 | + FROM Property p |
| 30 | + LEFT JOIN FETCH p.owner o |
| 31 | + LEFT JOIN FETCH p.categories c |
| 32 | + LEFT JOIN FETCH p.facilities f |
| 33 | + LEFT JOIN FETCH p.images |
| 34 | + LEFT JOIN FETCH o.image |
| 35 | + LEFT JOIN FETCH c.image |
| 36 | + LEFT JOIN FETCH f.image |
| 37 | + WHERE p.owner.email = :email |
| 38 | + """) |
| 39 | + List<Property> findAllByOwnerEmail(@Param("email") String email); |
| 40 | + |
| 41 | + @Query(""" |
| 42 | + SELECT DISTINCT p |
| 43 | + FROM Property p |
| 44 | + LEFT JOIN FETCH p.owner o |
| 45 | + LEFT JOIN FETCH p.categories c |
| 46 | + LEFT JOIN FETCH p.facilities f |
| 47 | + LEFT JOIN FETCH p.images |
| 48 | + LEFT JOIN FETCH o.image |
| 49 | + LEFT JOIN FETCH c.image |
| 50 | + LEFT JOIN FETCH f.image |
| 51 | + WHERE p.propertyId = :id |
| 52 | + """) |
| 53 | + Optional<Property> findById(@Param("id") long id); |
22 | 54 |
|
23 | 55 | } |
0 commit comments