작성
·
342
답변 1
0
안녕하세요, 인프런 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 테이블은 학생과 과목 테이블 간의 관계를 맺어줍니다. 이제 학생과 과목 테이블을 조회하면 양방향으로 연결된 결과를 얻을 수 있습니다.
양방향 관계를 사용하면 한 학생이 여러 과목을 수강할 수 있고, 각 과목도 여러 학생들이 수강할 수 있습니다. 따라서, 중간 테이블을 통해 다대다 관계를 구현할 수 있습니다.
이와 같은 방식으로 다대다 양방향 관계를 구현할 수 있으며, 중간 테이블을 통해 필요한 정보를 조회하고 조작할 수 있어요. 다만, 어떤 데이터베이스를 사용하느냐에 따라 구현 방법이 조금씩 다를 수 있으니 자신이 사용하는 데이터베이스의 문서를 참고하시면 도움이 될 거에요. 많은 학생들이 다양한 과목을 수강하길 바라요!