inflearn logo
강의

Course

Instructor

Spring MVC Part 2 - Backend Web Development Application Techniques

Spring and File Upload

특정 데이터와 파일을 함께 저장 시, 테이블 구조 질문

52

kym

1 asked

0


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

[질문 내용]
실무에서 특정 데이터와 파일을 함께 DB 저장 시 파일 테이블의 구조를 아래 두가지 케이스중 어떤 케이스로 구성하는지 궁금합니다.
(ex. A게시글과 A게시글에 대한 파일과 사진들 첨부 시)

1) 파일 테이블(file_table)에 관련된 게시글의 타입(ref_type)과 id(ref_id) 컬럼을 만들어 저장하는 것.

2) 게시글 테이블(board_table)에 관련된 파일 id(file_id) 컬럼을 만들어 저장하는 것.

2개 이상의 파일 list를 저장하고 관리하기에는 1번 방법이 더 직관적인 것 같은데, 실제로는 2번과 같은 구조를 많이 본 것 같아서 질문 드립니다.

실무에서는 보편적으로 어떤 구조를, 어떤 이유로 많이 사용할까요 ?

항상 감사합니다.

spring mvc

Answer 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 김용민님.

파일과 관련된 데이터 베이스 구조에 대한 질문을 주셨네요. 게시글과 관련된 파일을 DB에 저장하는 방법은 상황에 따라 달라질 수 있습니다. 각 방법의 특징을 간단히 설명드릴게요.

  1. 파일 테이블에 ref_type과 ref_id 컬럼을 추가하는 방법:

    • 파일 테이블에 게시글의 정보(ref_type, ref_id)를 추가해서 관리하는 방법입니다. 이렇게 하면 파일들이 다양한 유형의 데이터(예: 게시글, 댓글 등)와 연결될 수 있습니다.
    • 파일 테이블에서 파일이 어느 데이터에 속한 것인지를 쉽게 알 수 있어 확장성 있는 구조로 설계할 수 있습니다.
    • 게시글과 파일 간 1:N 관계를 설정하며, 여러 파일을 게시글 하나에 연결해야 할 경우에도 유연하게 대처할 수 있습니다.
  2. 게시글 테이블에 파일 id 컬럼을 추가하는 방법:

    • 게시글 테이블에 파일 id를 직접 추가하는 방법입니다.
    • 주로 파일이 게시글과 1:1 관계로 연결될 때 사용됩니다.
    • 하지만 여러 파일을 하나의 게시글에 연결해야 하는 경우에는 적합하지 않을 수 있습니다.

실무에서의 선택

실무에서는 확장성과 유지 보수를 고려하여 압도적으로 첫 번째 방법을 많이 사용합니다. 특히 여러 파일을 다루어야 하는 경우와 다양한 데이터 타입에 대해 파일이 연결되어야 하는 상황에서는 첫 번째 방법이 훨씬 유리합니다. 이를 통해 파일을 효과적으로 관리하고, 다른 데이터와의 관계를 명확히 할 수 있기 때문입니다.

관련 게시물로는 다음을 살펴볼 수 있습니다:
- 게시물과 첨부파일의 연관관계 매핑 방법
- db 저장 문제 ..

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

이미지 업로드와 db 트랜잭션 묶는법

0

38

1

Could not resolve org.springframework.boot:spring-boot-starter-validation:2.4.4

0

43

2

MessageSourceTest 코드

0

44

1

인터셉터 에러 설정

0

47

1

resolveArgument()메서드 질문

0

54

1

43강 검증1 에서 실패 로직 관련 질문있습니다.

0

52

2

타임리프 3.X 버전 rendering, serializer 에러 해결 방법

2

130

3

스프링 빈에 등록이 안되는거 같은데 어떻게 하면 좋을까요?ㅠㅠ

0

86

3

pdf 오타 문의

0

54

1

ItemUpdateForm 검증 관련 질문입니다.

0

46

1

22page 링크 주소 변경

0

54

2

섹션3번 수업에 대한 질문입니다.

0

78

2

@Autowired 보다 더 좋은 방법이 어떤 걸까요?

0

84

2

타입컨버터 가 람다랑 비슷해 보이는데 저의 생각이 맞는지?.

0

63

1

자바스크립트 인라인에서 객체 직렬화 시 오류가 납니다

0

140

3

스프링부트 - 오류페이지2 에서 500.html 에서 쓰인 객체 질문

0

61

1

톰캣 에러 페이지가 안보입니다.

0

98

2

apiEceptionController에서 센드 에러 호출하면 안되는지?

0

80

1

세션 타임아웃시 쿠키 삭제 방법이 없나요?

0

116

2

ApiExceptionController 질문드립니다.

0

62

1

셀렉박스 챕터에서 option value에 ==배송 방식 선택== 이것을 넣은 이유가 궁금함, 이렇게 구상해도 되는지?

0

63

1

MemberRepository 필드의 fianl 선언 유무

0

80

2

혹시 index.html 에서는 fragment 사용이 안되는건가요

0

56

1

helloMessage테스트 오류

0

129

2