inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

탄탄한 백엔드 NestJS, 기초부터 심화까지

요구사항에 맞는 도메인 설계, ERD 모델링에 대하여

OneToOne 관계

319

cyun0717

작성한 질문수 3

0

USER와 Profile테이블은 OneToOne 관계입니다.

근데 서로 하나씩만 존재하다면 그냥 USER테이블에 Profile을 넣어버리면 되는거 아닌가요?

OneToOne 관계를 유지하는 특별한 이유가 있나요??

하나의 테이블이 커지는걸 방지하기 위해 OneToOne 관계를 형성하는 걸까요?

 

node.js mongodb express nestjs ssr

답변 1

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.

OneToOne 관계는 두 엔티티 간에 하나의 행만 매핑이 가능한 관계입니다. 여기서 Profile 테이블이 User와 OneToOne 관계를 가지면, Profile 당 한개의 User 행만을 갖습니다. 이 관계를 유지하는 특별한 이유는 각각의 엔티티가 서로 다른 개념이기 때문에 분리를 유지해야 할 경우가 많기 때문입니다.

그리고, User 테이블에 Profile을 포함시켜버린다면, Profile 테이블이 필요하지 않기 때문에 더 이상 프로필 정보를 담을 테이블이 없어지게 됩니다. 하지만, 만약에 사용자가 여러 개의 프로필을 가지거나 Profile 정보에 하위 테이블이 더 존재한다면, User 테이블에 Profile을 넣음으로써 테이블이 더 복잡해지게 됩니다. 그러므로, OneToOne 관계를 유지함으로써 각각의 엔티티를 분리하여 보다 명확한 데이터 구조를 유지할 수 있습니다.

따라서, OneToOne 관계는 테이블의 크기를 줄이는 것이 아니라 분리를 유지하여 데이터 구조의 명확성을 유지하기 위해 사용됩니다.

참고하시길 바랍니다. 감사합니다.

프로젝트 환경 세팅할 때 최신 노드 버젼을 사용하시는 분들은 참고하셔도 좋을 것 같아요~

2

83

1

DTO에 대한 질문

1

88

2

백엔드 MVC에서 View의 역할은 무엇인가요?

1

95

2

추가 업데이트 관련 건

0

92

2

nest js 버전문제

0

81

2

mongdb 스키마 공식 문서와 형태가 다른 이유 궁금합니다.

0

103

1

라인 끝에 에러 표시(eslint) 때문에 구글 찾아 보니.

0

77

1

전체 고양이 조회 라우터 중 error.message 오류

0

70

1

캡슐화 추가 설명 중 단일책임원칙 관련 질문

0

106

0

TypeORM과 mysql을 사용하시는 분들

4

143

1

42강 고양이끼리 소통 댓글 구현 중 Schema hasn't been registered for model 'comments' 에러 해결

0

82

1

채팅 이슈

0

134

1

모듈이 더 이상 지원하지 않는답니다

0

207

1

오류가 있습니다

0

107

1

import 에서 오류가 납니다

0

128

1

이런 오류가 나옵니다

0

101

1

에러가 발생합니다

0

111

1

프론트 에러 뜨는데 수정 안해주시나요

0

159

1

emit() broadcast.emit() 질문있습니다

0

103

1

서버연결이 안됩니다.

1

403

1

[PM2][ERROR] Command not found

0

521

1

S3에 업로드까지는 성공했는데 사진이 나오지 않습니다.

0

248

1

error_code : Property 'user' does not exist on type 'Request<ParamsDictionary, any, any, ParsedQs, Record<string, any>>'.ts(2339)

0

603

1

jwt를 따로 연습하고 있는데 env를 못읽는 것 같습니다.

0

324

2