인프런 커뮤니티 질문&답변
INSERT SQL이 나가지 않는 이유가 궁금합니다!
작성
·
412
퀴즈
61%나 틀려요. 한번 도전해보세요!
객체와 관계형 데이터베이스가 관계를 표현하는 방식의 근본적인 차이는 무엇일까요?
객체는 ID, 테이블은 이름
객체는 참조, 테이블은 외래 키
객체는 속성, 테이블은 레코드
객체는 단방향, 테이블은 양방향
답변 2
2
김영한
지식공유자
안녕하세요. 이한별님^^
entityManager.find(Member.class, "member1") -> 이 부분이 문제입니다.
Member의 PK는 데이터 타입이 Long 입니다. 그런데 문자인 "member1"을 입력해서 해당 라인에서 예외가 발생했습니다.
코드를 다음과 같이 해서 e.printStackTrace()로 예외를 출력해보시면 바로 보이실 꺼에요
try {
Team team = new Team();
team.setName("TeamA");
em.persist(team);
Member member = new Member();
member.setUsername("member1");
member.setTeam(team);
em.persist(member);
Member member1 = em.find(Member.class, "member1");
tx.commit();
} catch (Exception e) {
e.printStackTrace(); //이 부분을 추가하면 예외를 확인할 수 있습니다.
tx.rollback();
}
entityManager.find(Member.class, "member1") 이 부분을 Long 타입의 id 값을 조회하도록
entityManager.find(Member.class, 1L) -> 이런식으로 변경해보시면 문제가 발생하지 않을꺼에요^^
그래도 두번째 예시에서는 잘 동작했습니다.
도움이 되셨길 바래요^^
1





