작성
·
223
0
안녕하세요. 실습을 따라하던중에 실수로 잘못 따라치다가 발견한부분인데요.
//저장
Team team = new Team();
team.setName("TeamA");
em.persist(team);
Member member = new Member();
// member.setName("member1");
// member.setTeam(team);
// em.persist(member);
em.flush(); // 강제로 insert
Member findMember = em.find(Member.class, member.getId());
tx.commit();
위 코드처럼 member를 영속화하지 않고 find를 하게되면 트랜잭션 문제때문에 rollback되어서 처음 persist했던 teamA는 db에 안들어가더라구요. flush로 강제로 넣어도 롤백되어서 db에 반영이 안되는 것 까진 알겠는데,
그러면 find() 부분에 문제가생기면 바로 catch문으로 빠져서 롤백되는거라고 생각했습니다.
그러면 persist로 영속화했던 teamA에 관한것도 버려지니까 그냥 종료가 될 줄 알았는데,
콘솔 제일 마지막에
Hibernate:
call next value for hibernate_sequence
이게 뜨더라구요. 근데 저건 insert 하기직전에 호출되는거 아닌가요? 트랜잭션 오류나면 commit은 실행안될탠데 insert문이 날라가려고 하는느낌?이라서 궁금해서 질문드립니다.
답변 4
1
1
1
헉,, 제가 수업을 잘 안들었네요,,
Member member = new Member();
member.setName("member1");
em.persist(member);
여기서 기본키를 안넣어 주었기때문에 persist할 때 call next value으로 키를 얻어온거네요..?
1
안녕하세요. 승빈님
트랜잭션 커밋 없이
딱 다음까지만 실행해보시겠어요?
//저장
Team team = new Team();
team.setName("TeamA");
em.persist(team);
그리고 섹션 3 영속성 관리 부분을 다시 한번 복습해주세요^^
(만약 섹션3을 복습하고 이해가 잘 안되면 다시 글 남겨주세요^^!)
감사합니다.