티스토리 뷰
JPA에서 @Query
애너테이션을 사용할 때, 일반적으로 @Param
애너테이션을 사용하여 파라미터명과 매핑할 이름을 지정해주어야 합니다.
하지만 다음과 같은 경우에는 @Param
을 생략할 수 있습니다.
파라미터명과 매핑할 이름이 동일한 경우
예를 들어, 다음과 같이 파라미터명과 매핑할 이름이 모두 "name"인 경우에는 @Param
을 생략할 수 있습니다.
@Query("SELECT u FROM User u WHERE u.name = :name")
User findByName(String name);
파라미터가 하나인 경우
파라미터가 하나뿐인 경우에는 @Param
을 생략할 수 있습니다. 이 경우에는 파라미터명과 매핑할 이름이 자동으로 "0", "1", "2" 등으로 지정됩니다.
@Query("SELECT u FROM User u WHERE u.name = ?1")
User findByName(String name);
Spring Data JPA 2.0 이상을 사용하는 경우
Spring Data JPA 2.0 이상부터는 파라미터명과 매핑할 이름을 지정하지 않아도 자동으로 매핑됩니다.
@Query("SELECT u FROM User u WHERE u.name = :name")
User findByName(String name);
따라서 위의 경우들에 해당하지 않는 한, @Param
을 사용하여 파라미터명과 매핑할 이름을 지정해주는 것이 좋습니다.
특히 JPA 2.0이상을 사용해서 @Param
을 붙여주지 않은 경우, 더 낮은 버전에서 같은 코드를 사용할 경우 에러가 발생하게 되므로 버전의 싱크를 맞추든지 하위 호환이 가능하도록 코딩하는 습관을 들여야 하겠네요.
'JPA' 카테고리의 다른 글
JPA @Where 애너테이션 (0) | 2022.09.12 |
---|---|
[JPA] 암호화 컨버터가 있는 컬럼을 조건절에서 비교할 때 평문을 사용할까 암호문을 사용할까? (2) | 2022.08.21 |
[JPA] 데이터 타입 (0) | 2022.07.13 |
[JPA] 고아 객체 (0) | 2022.07.12 |
[JPA] 영속성 전이(Cascade) (0) | 2022.07.10 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- JSON
- 스프링 부트 튜토리얼
- 클린 아키텍처
- 알고리즘
- 스프링 데이터 jpa
- spring boot application
- Spring Data JPA
- intellij
- 헥사고날 아키텍처
- spring boot jwt
- Spring Boot Tutorial
- Jackson
- 스프링 부트
- Linux
- Spring Boot JPA
- 함께 자라기
- proto3
- 스프링부트
- gRPC
- Spring Boot
- spring boot app
- 스프링 부트 애플리케이션
- QueryDSL
- r
- 함께 자라기 후기
- Java
- JPA
- 스프링 부트 회원 가입
- @ManyToOne
- leetcode
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
글 보관함