inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바 ORM 표준 JPA 프로그래밍 - 기본편

다대다 [N:M]

다대다 양방향은 어떻게 사용해야하나요 ?

415

김슬기

작성한 질문수 1

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (/아니오)

[질문 내용]
수업에 다대다 단방향만나와서 양방향하는 방법을 알고 싶습니다.
쉽게 말해서 한 학생이 여러과목을 들을 수 있는데 과목의 입장에서는 다양한 학생들이 있으니 그렇게 양방향으로 보고 싶습니다.

java jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요. 다대다 양방향 관계를 구현하려면 보통 관계형 데이터베이스에서 중간 테이블을 사용합니다. 중간 테이블은 다대다 관계에 있는 두 개의 테이블을 연결하는 역할을 합니다.

예를 들어, 학생과 과목의 다대다 관계에서 학생들이 수강하는 과목을 저장하고 싶다면, 다음과 같이 중간 테이블을 생성할 수 있습니다.

CREATE TABLE students (
  student_id INT PRIMARY KEY,
  student_name VARCHAR(100)
);

CREATE TABLE subjects (
  subject_id INT PRIMARY KEY,
  subject_name VARCHAR(100)
);

CREATE TABLE student_subjects (
  student_id INT,
  subject_id INT,
  FOREIGN KEY (student_id) REFERENCES students(student_id),
  FOREIGN KEY (subject_id) REFERENCES subjects(subject_id)
);

이렇게 생성한 student_subjects 테이블은 학생과 과목 테이블 간의 관계를 맺어줍니다. 이제 학생과 과목 테이블을 조회하면 양방향으로 연결된 결과를 얻을 수 있습니다.

양방향 관계를 사용하면 한 학생이 여러 과목을 수강할 수 있고, 각 과목도 여러 학생들이 수강할 수 있습니다. 따라서, 중간 테이블을 통해 다대다 관계를 구현할 수 있습니다.

이와 같은 방식으로 다대다 양방향 관계를 구현할 수 있으며, 중간 테이블을 통해 필요한 정보를 조회하고 조작할 수 있어요. 다만, 어떤 데이터베이스를 사용하느냐에 따라 구현 방법이 조금씩 다를 수 있으니 자신이 사용하는 데이터베이스의 문서를 참고하시면 도움이 될 거에요. 많은 학생들이 다양한 과목을 수강하길 바라요!

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

21

2

inheritance startegy 선택시 고려사항

0

21

1

Entity 동등성 비교

0

18

1

실무 조언 관련 질문입니다.

0

44

1

H2데이터베이스 파일 생성

0

56

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

52

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

51

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

92

2

UnsupportedOperationException 발생

0

85

3

H2 Database 연결이 안됩니다.

0

92

2

연관관계 매핑 질문드립니다.

0

85

2

h2데이터베이스 실행오류

0

107

2

persistence.xml

0

106

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

80

1

영속성 컨텍스트

0

65

1

JPA 프록시

0

94

1

Native Query와 MyBatis

0

67

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

85

1

임베디드 타입 예시 코드 관련 질문

0

114

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

94

3

인텔리제이 패키지 커서 단축키 질문

0

108

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

143

1