DB에 저장되어 있는 Entity를 조회하지 않고 새로 생성해서 값을 넣고 사용해도 되나요?
408
작성한 질문수 11
안녕하십니까! JPA를 친구와 학습하다가 서로 의문인 점을 얘기하다가 잘 몰라서 질문드립니다!
예시를 들자면 "member1"이라는 회원을 새로 등록해야합니다.
이 때 DB에 저장되어 있는 "teamA" 소속입니다.
그리고 팀에서 pk를 제외한 값들은 바뀔일이 크게 없습니다.
저는 DB의 정합성과 무결성을 지켜야하므로 "teamA"를 조회해서 "member1"을 등록해야한다! 였습니다.
친구는 "그러면 'teamA'를 조회하는 쿼리가 1번 날라가는데 차라리 'teamA'에 소속되어 있는것을 알고 있고 이 팀의 값은 바뀌지 않으니까 이걸 새로 생성해서 'member1'을 등록하면 되지 않냐?" 였습니다.
나 : DB에서 팀을 조회해서 회원을 등록해야한다.
친구 : 쿼리1번 줄이기 위해 팀을 새로 생성하고 회원을 등록한다.
이에 다음 코드로 실험을 진행하였습니다.

결과는 insert가 잘 되었고 'member1'도 'teamA'에 소속되어서 DB에 잘 저장 되었습니다.
이 때 저는 "만약에 등록하기 직전에 'teamA'의 값이 DB에서 바뀌었으면 에러가 나지 않겠냐" 였습니다.
하지만 이번 강의에서도 봤듯이 외래키인 'teamA'를 사용하여 회원을 등록할 때 entity 전체값이 아닌 그 중 pk값으로만 인식하기에 DB에서 팀 이름을 바꾸고 저장하여도 잘 저장되었습니다.
그래서 저는 의문이 들었습니다.
- 단순하게 저장만 할 때는 'teamA'를 조회하는 쿼리를 줄여서 등록해도 될까요?
- 만약에 회원 등록이 페이지 조회하듯이 많이 일어나는 이벤트라면 이 때 1번의 쿼리가 성능 차이를 꽤 보일텐데 이 때 사용해도 될까요?
답변 1
1
안녕하세요. tkddyd420님
다음을 참고해주세요.
https://www.inflearn.com/questions/204850
https://www.inflearn.com/questions/74141
감사합니다.
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
58
2
inheritance startegy 선택시 고려사항
0
42
1
Entity 동등성 비교
0
47
1
실무 조언 관련 질문입니다.
0
68
1
H2데이터베이스 파일 생성
0
78
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
70
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
63
1
JPQL 메소드와 락
0
63
1
Delivery @OneToOne
0
73
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
105
2
UnsupportedOperationException 발생
0
97
3
H2 Database 연결이 안됩니다.
0
103
2
연관관계 매핑 질문드립니다.
0
95
2
h2데이터베이스 실행오류
0
116
2
persistence.xml
0
121
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
90
1
영속성 컨텍스트
0
77
1
JPA 프록시
0
107
1
Native Query와 MyBatis
0
83
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
97
1
임베디드 타입 예시 코드 관련 질문
0
126
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
103
3
인텔리제이 패키지 커서 단축키 질문
0
113
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
156
1





