2026년 상식닷컴 선정 식당 & 카페 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요

MySQL에서 중간 테이블에 데이터를 삽입하는 올바른 쿼리 예시는 무엇인가요?

_____
Q: MySQL에서 중간 테이블에 데이터를 삽입하는 올바른 쿼리 예시는 무엇인가요?

A: 중간 테이블(조인 테이블)은 보통 다대다(M:N) 관계를 표현하기 위해 두 개 이상의 외래 키를 포함합니다. 중간 테이블에 데이터를 삽입할 때는 이 외래 키 값들을 정확히 지정해야 합니다.

예를 들어, `students` 테이블과 `courses` 테이블이 있고, 이 둘의 다대다 관계를 표현하는 중간 테이블 `student_courses`가 다음과 같은 구조라고 가정합시다.

```sql
CREATE TABLE student_courses (
student_id INT NOT NULL,
course_id INT NOT NULL,
PRIMARY KEY (student_id, course_id),
FOREIGN KEY (student_id) REFERENCES students(id),
FOREIGN KEY (course_id) REFERENCES courses(id)
);
```

이 경우, 중간 테이블에 데이터를 삽입하는 기본 쿼리 문법은 다음과 같습니다.

```sql
INSERT INTO student_courses (student_id, course_id)
VALUES (1, 101);
```

여기서 `1`은 `students` 테이블의 한 학생 ID, `101`은 `courses` 테이블의 한 강좌 ID입니다.

---
중요 포인트
- 외래 키 제약 조건을 만족하는 값 을 반드시 이용해야 합니다. 즉, `students`와 `courses` 테이블에 해당하는 `student_id`와 `course_id`가 존재해야 삽입이 성공합니다.
- 중간 테이블 컬럼명과 순서를 정확히 명시하거나, 순서를 기억하고 일치시켜야 합니다.
- 다중 행 삽입도 가능합니다.

예시) 다중 행 삽입

```sql
INSERT INTO student_courses (student_id, course_id)
VALUES (1, 101), (1, 102), (2, 101);
```

---

정리

- 중간 테이블 삽입 쿼리 기본 형태:
```sql
INSERT INTO 중간테이블명 (외래키1, 외래키2, ...)
VALUES (값1, 값2, ...);
```
- 외래 키 존재 여부, 데이터 타입, 제약 조건을 반드시 확인!
- 환경에 따라 추가 컬럼이 있다면 같이 넣어야 함.

---

이와 같은 방법으로 MySQL에서 중간 테이블에 올바르게 데이터를 삽입할 수 있습니다.
MySQL에서 중간 테이블에 데이터를 삽입하는 것은 일반적으로 다대다 관계를 관리하기 위해 사용됩니다.

중간 테이블은 두 개 이상의 테이블 간의 관계를 정의하고, 이 관계를 통해 데이터를 연결하는 역할을 합니다.

예를 들어, 학생과 수업 간의 관계를 관리하기 위해 `students` 테이블과 `courses` 테이블이 있을 때, 이 두 테이블 간의 관계를 나타내기 위해 `enrollments`라는 중간 테이블을 사용할 수 있습니다.

예시 테이블 구조 1. students 테이블 - `student_id` (Primary Key) - `student_name`

2. courses 테이블 - `course_id` (Primary Key) - `course_name`

3. enrollments (중간 테이블) - `student_id` (Foreign Key) - `course_id` (Foreign Key) 테이블 생성 쿼리 ```sql CREATE TABLE students ( student_id INT AUTO_INCREMENT PRIMARY KEY, student_name VARCHAR(100) NOT NULL ); CREATE TABLE courses ( course_id INT AUTO_INCREMENT PRIMARY KEY, course_name VARCHAR(100) NOT NULL ); CREATE TABLE enrollments ( 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) ); ``` 데이터 삽입 예시 이제 중간 테이블인 `enrollments`에 데이터를 삽입하는 방법을 살펴보겠습니다.

먼저 `students`와 `courses` 테이블에 데이터를 삽입한 후, 이 데이터를 기반으로 `enrollments` 테이블에 데이터를 삽입할 수 있습니다.

```sql -- 학생 데이터 삽입 INSERT INTO students (student_name) VALUES ('Alice'); INSERT INTO students (student_name) VALUES ('Bob'); -- 수업 데이터 삽입 INSERT INTO courses (course_name) VALUES ('Mathematics'); INSERT INTO courses (course_name) VALUES ('Science'); -- enrollments 테이블에 데이터 삽입 INSERT INTO enrollments (student_id, course_id) VALUES (1, 1); -- Alice가 Mathematics 수업에 등록 INSERT INTO enrollments (student_id, course_id) VALUES (1,

2); -- Alice가 Science 수업에 등록 INSERT INTO enrollments (student_id, course_id) VALUES (2, 1); -- Bob이 Mathematics 수업에 등록 ``` 데이터 확인 데이터가 올바르게 삽입되었는지 확인하기 위해 다음과 같은 쿼리를 사용할 수 있습니다.

```sql SELECT s.student_name, c.course_name FROM enrollments e JOIN students s ON e.student_id = s.student_id JOIN courses c ON e.course_id = c.course_id; ``` 이 쿼리는 `enrollments` 테이블을 통해 학생과 수업의 관계를 조회하여, 어떤 학생이 어떤 수업에 등록했는지를 보여줍니다.

결론 중간 테이블을 사용하여 다대다 관계를 관리하는 것은 데이터베이스 설계에서 매우 중요한 부분입니다.

위의 예시를 통해 중간 테이블에 데이터를 삽입하는 방법과 이를 활용하여 관계를 조회하는 방법을 이해할 수 있습니다.

이러한 구조는 데이터의 무결성을 유지하고, 관계형 데이터베이스의 장점을 극대화하는 데 기여합니다.

작성자: 최재민 [비회원] | 작성일자: 1년 전 2024-09-21 05:50:46
조회수: 110 | 댓글: 0 | 좋아요: 0 | 싫어요: 0
내용이 부정확하다면 싫어요를 클릭해주세요.