상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
궁금한 상식 보기
코스타리카의 전통적인 가옥 구조는 어떤가요?
코스타리카의 경제 성장률은 어떤가요?
코스타리카의 주요 해양 스포츠는 무엇인가요?
코스타리카의 유명한 관광 가이드북은 무엇인가요?
인감증명과 공증의 차이는 무엇인가요?
건강보험의 의료비 지원 한도는 어떻게 되나요?
아파트 투자에서의 계약 해지 조건은?
아파트 투자 시 자산 포트폴리오 구성 방법은?
서울 아파트의 임대차 계약 기간은 어떻게 되나요?
서울 아파트의 주택 구매 시 세금 혜택은 무엇인가요?
서울 아파트의 주거 안정성을 높이기 위한 정책은 무엇인가요?
다주택자의 세금 신고 시 주의해야 할 점은 무엇인가요?
Previous
Next
수정하기 - MySQL에서 many-to-many 관계에서 각 테이블의 기본 키 설정 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
MySQL에서 many-to-many 관계를 설정할 때, 두 개의 테이블 간의 관계를 관리하기 위해 중간 테이블(조인 테이블 또는 연관 테이블)을 사용합니다. 이 중간 테이블은 두 개의 테이블의 기본 키를 외래 키로 포함하여 관계를 정의합니다. 아래에서는 many-to-many 관계를 설정하는 방법과 각 테이블의 기본 키 설정 방법에 대해 자세히 설명하겠습니다. 1. 기본 테이블 정의 먼저, 두 개의 기본 테이블을 정의합니다. 예를 들어, `students`와 `courses`라는 두 개의 테이블이 있다고 가정해 보겠습니다. ```sql CREATE TABLE students ( student_id INT AUTO_INCREMENT P<a href='https://sangseek.com/sangseeks/RIM/ko'>RIM</a>ARY KEY, name VARCHAR(100) <a href='https://sangseek.com/sangseeks/NOT NULL/ko'>NOT NULL</a> ); CREATE TABLE courses ( course_id INT AUTO_INCREMENT PRIMARY KEY, title VARCHAR(100) NOT NULL ); ``` 위의 SQL 문에서 `students` 테이블은 `student_id`를 기본 키로 사용하고, `courses` 테이블은 `course_id`를 기본 키로 사용합니다. `AUTO_INCREMENT` 속성을 사용하여 각 레코드가 추가될 때마다 자동으로 증가하는 값을 생성합니다. 2. 중간 테이블 정의 이제 `students`와 `courses` 간의 many-to-many 관계를 정의하기 위해 중간 테이블을 생성합니다. 이 테이블은 두 테이블의 기본 키를 외래 키로 포함합니다. ```sql CREATE TABLE student_courses ( student_id INT, course_id INT, PRIMARY KEY (student_id, course_id), FOREIGN KEY (student_id) REFERENCES students(student_id), FOREIGN KEY (course_id) REFERENCES courses(course_id) ); ``` 위의 SQL 문에서 `student_courses` 테이블은 `student_id`와 `course_id`를 포함하고 있으며, 이 두 컬럼을 조합하여 복합 기본 키를 설정합니다. 이렇게 하면 각 학생이 어떤 과목을 수강하는지를 나타내는 레코드를 생성할 수 있습니다. 3. 기본 키 설정 방법 - 기본 키 : 각 테이블의 기본 키는 해당 테이블의 각 레코드를 고유하게 식별하는 데 사용됩니다. `students` 테이블의 `student_id`와 `courses` 테이블의 `course_id`는 각각의 테이블에서 고유한 값을 가지며, 이를 통해 각 학생과 각 과목을 식별할 수 있습니다. - 복합 기본 키 : 중간 테이블인 `student_courses`에서는 `student_id`와 `course_id`를 조합하여 복합 기본 키를 설정합니다. 이 복합 키는 특정 학생이 특정 과목을 수강하는 유일한 조합을 보장합니다. 즉, 같은 학생이 같은 과목을 여러 번 수강할 수 없도록 합니다. 4. 데이터 삽입 예시 이제 테이블이 설정되었으므로, 데이터를 삽입해 보겠습니다. ```sql INSERT INTO students (name) VALUES ('Alice'); INSERT INTO students (name) VALUES ('Bob'); INSERT INTO courses (title) VALUES ('Mathematics'); INSERT INTO courses (title) VALUES ('Science'); INSERT INTO student_courses (student_id, course_id) VALUES (1, 1); -- Alice가 Mathematics 수강 INSERT INTO student_courses (student_id, course_id) VALUES (1, 2); -- Alice가 Science 수강 INSERT INTO student_courses (student_id, course_id) VALUES (2, 1); -- Bob이 Mathematics 수강 ``` 5. 데이터 조회 예시 이제 학생과 그들이 수강하는 과목을 조회할 수 있습니다. ```sql SELECT s.name, c.title FROM student_courses sc JOIN students s ON sc.student_id = s.student_id JOIN courses c ON sc.course_id = c.course_id; ``` 위의 쿼리는 학생의 이름과 그들이 수강하는 과목의 제목을 반환합니다. 결론 MySQL에서 many-to-many 관계를 설정하기 위해서는 두 개의 기본 테이블과 중간 테이블을 정의해야 합니다. 각 테이블의 기본 키는 해당 테이블의 레코드를 고유하게 식별하며, 중간 테이블에서는 두 테이블의 기본 키를 외래 키로 사용하여 관계를 정의합니다. 이러한 구조를 통해 데이터의 무결성을 유지하고, 복잡한 관계를 효과적으로 관리할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기