싱글 테이블 전략
471
작성한 질문수 36
싱글 테이블 전략을 사용하면 db에 저장시 dtype이 생기는데요
테스트를 하던 도중, Book 타입을 조회할려고 코드를 작성했는데 dtype은 엔티티로 접근을 못하더라구요..?
접근을 못하니 JPQL으로 작성하면 오류가 납니다 ㅜ
dtype으로 조회하고 싶을 때는 어떻게 해야하나요?
제가 작성한 코드
public void itemFindTest() {
Item book = new Book("JPA", 10000, 10, "김영한", "123");
Item album = new Album("베토벤", 20000, 20, "베토벤", "교향곡");
em.persist(book);
em.persist(album);
em.flush();
em.clear();
List<Item> resultList = em.createQuery(
"select i from Item i where i.dtype = :type", Item.class
)
.setParameter("type", "BOOK")
.getResultList();
}
디비에는 아래와 같이 잘 저장되어있습니다.
답변 1
0
안녕하세요. 조윤호님, 공식 서포터즈 OMG입니다.
.setParameter("type", "BOOK" -> "Book") 으로 변경해보시겠어요?
변경 후 결과를 공유해주세요.
감사합니다.
0
아 저건 제 오타입니다 원래는 book으로 시도했었고
위에 질문글에 말씀드린것처럼
i.dtype 에서 dtype이 인식이 안됩니다.
관련 오류 코드도
org.hibernate.QueryException: could not resolve property: dtype of: jpa.practice3.domain.item.Item [select i from jpa.practice3.domain.item.Item i where i.dtype = :type]
java.lang.IllegalArgumentException: org.hibernate.QueryException: could not resolve property: dtype of: jpa.practice3.domain.item.Item [select i from jpa.practice3.domain.item.Item i where i.dtype = :type]
라고 뜨구요
원래 dtype은 JPQL에서 접근을 못하는지에 대한 질문입니다!
0
네, DTYPE이 기존 ITEM엔티티의 필드가 아니다보니 JPQL로는 접근이 불가한 것 같네요.
대신 네이티브쿼리로 접근하면 확인 가능합니다.
제가 테스트 한 환경은
제공해드리는 프로젝트 환경(초기 데이터 4건, DTYPE=B) 에서 H2에 접속해서 한개의 상품의 DTYPE을 바꿨습니다.
해당 상황에서 네이티브 쿼리로 조회시 3건이 조회되네요.
OrderServiceTest 상문주문 테스트 시 update 쿼리 문의
0
27
1
sdk 설정 오류
0
65
2
오탈자 - @Transactional
0
62
1
src/test/resources 테스트 경로 문제
0
56
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
70
1
MemberRepositoryTest 실행오류
0
89
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
195
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
153
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
56
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
80
1
기본 생성자
0
66
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
106
1
멤버서비스테스트 부분에서 막힙니다.
0
173
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
124
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
128
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
121
1
24분 27초 연관관계 편의 메서드 위치
0
118
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
114
2
빌드 툴, Gradle
0
63
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
81
2
Repository에서 EntityManager 주입 방식 차이
0
97
1
롬복과 사용자 정의 setter 메서드
0
77
1
주문 목록 조회 fetch join 질문드립니다
0
91
1
dirty checking 질문드립니다.
0
86
1





